How to create a UDF that takes a query string and returns the query's resultset
        Posted  
        
            by Martin
        on Stack Overflow
        
        See other posts from Stack Overflow
        
            or by Martin
        
        
        
        Published on 2009-04-24T16:46:58Z
        Indexed on 
            2010/04/02
            1:03 UTC
        
        
        Read the original article
        Hit count: 633
        
I want to create a stored procedure that takes a simple SELECT statement and return the resultset as a CSV string. So the basic idea is get the sql statement from user input, run it using EXEC(@stmt) and convert the resultset to text using cursors. However, as SQLServer doesn't allow:
- select * from storedprocedure(@sqlStmt)
- UDF with EXEC(@sqlStmt)
so I tried Insert into #tempTable EXEC(@sqlStmt), but this doesn't work (error = "invalid object name #tempTable").
I'm stuck. Could you please shed some light on this matter?
Many thanks
EDIT:
Actually the output (e.g CSV string) is not important. The problem is I don't know how to assign a cursor to the resultset returned by EXEC. SP and UDF do not work with Exec() while creating a temp table before inserting values is impossible without knowing the input statement.
I thought of OPENQUERY but it does not accept variables as its parameters.
© Stack Overflow or respective owner