-1

我正在开发一个应用程序,我需要在其中根据员工的进出条目生成报告。我没有使用动态查询的数据库相关应用程序的经验。在这个特定的应用程序中,我需要传递动态 sql 查询。

在此我需要根据用户选择选择列名,然后将它们作为参数传递给另一个 sql 查询。这是查询...

DECLARE @cols AS NVARCHAR(MAX),

    @query  AS NVARCHAR(MAX)


select @cols = STUFF((SELECT ',' + QUOTENAME(date +'_'+Logname) 
                    from
                    (
                      select doordate,
                        convert(char(10),doordate, 101) date, 
                        LogName
                      from DoorLog
                      cross apply
                      (
                        select 'In' LogName
                        union all
                        select 'Out' 
                      ) l
                    ) s   
                    group by convert(char(10), doordate, 112), date, Logname
                    order by convert(char(10), doordate, 112)
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') 
        ,1,1,'')

set @query 
    = 'select employeeid, name, '+@cols+'
       from
       (
         select employeeid, name, 
          convert(char(8), doortime, 108) DoorTime,
          date + ''_''+ col col_names
         from
         (
            select p.employeeid,
              p.name,
              convert(char(10),d.doordate, 101) date,
              min(d.doordate) [In],
              max(d.doordate) [Out]
            from person p
            left join doorlog d
              on p.employeeid = d.employeeid
            group by p.employeeid, p.name, 
              convert(char(10),d.doordate, 101)
         )src
         unpivot
         (
           doortime
           for col in ([In], [Out])
         ) unpiv
       ) p
       pivot
       (
          max(doortime)
          for col_names in('+@cols+')
       ) piv'

execute(@query)

我一直无法想出如何在 C# 代码中使用此代码的方法。

请帮忙。

提前致谢 ...

4

1 回答 1

1

您最好的选择是在您的数据库中创建一个可以处理传入请求并执行查询的存储过程。以下是有关存储过程的更多信息:

http://msdn.microsoft.com/en-us/library/aa174792(v=sql.80).aspx

然后,您需要在 C# 代码中创建与数据库的连接:

http://msdn.microsoft.com/en-us/library/s4yys16a(v=vs.71).aspx

最后,您需要使用刚刚创建的连接调用存储过程,并从 C# 代码中传递参数,这在 StackOverflow 上已多次回答:

如何在 C# 程序中执行存储过程

于 2013-03-21T08:00:48.643 回答