T4模板:读取存储过程表的结果列

时间:2011-07-03 16:26:20

标签: templates t4

我正在学习T4模板,我在互联网上获得的所有示例都是关于使用表格生成代码。我想使用存储过程结果列来生成自动UI,是否可能?或者我必须为同一个查询创建视图?在这种情况下,如何从视图中读取?

提前致谢。

2 个答案:

答案 0 :(得分:0)

我得到了解决方案,以下是如何直接从sp名称生成rad网格


<#
'requires: <#@ assembly name="System.Data" #>
  dim Server as new Server(".\sqlexpress")
    dim database as new Database(server, "xxxx")
    dim strSpName as String= "sp_xxxx"
    Dim dt as System.Data.DataTable= database.ExecuteWithResults("exec sp_GetEquipment").Tables(0)
    dim ctlName as String = "grdEqp"
#>
<telerik:RadGrid ID="grd" runat="server" Skin="Web20" AutoGenerateColumns="false">
<MasterTableView>
<Columns>

<#
    For Each column As System.Data.DataColumn In dt.Columns
#><telerik:GridBoundColumn DataField="<#=column.ColumnName #>" HeaderText="<#=column.ColumnName  #>"/>
<#Next#>
</Columns>
                </MasterTableView>
</telerik:RadGrid>

答案 1 :(得分:0)

如果您实际上不想执行存储过程,因为各种存储过程都传递了许多不同的参数,那么您可以使用sp_describe_first_result_set系统存储过程返回结果集的列,假设只有一个。< / p>

    /// <summary>
/// Returns table for which stored procedures need to be generated.
/// </summary>

string TableName = "usp_getNominalCode";

string SchemaName = "Financial";

DataTable DataTable
{
    get
    {
        if (_table == null)
        {
            Server server = new Server(new ServerConnection(new SqlConnection(this.ConnectionString)));
            SqlConnectionStringBuilder connectionStringBuilder = new SqlConnectionStringBuilder(this.ConnectionString);
            Database database = new Database(server, connectionStringBuilder.InitialCatalog);
            DataSet storedProcedureColumns = database.ExecuteWithResults("sp_describe_first_result_set @tsql= " + "'[" + SchemaName + "]" + ".[" + TableName + "]'");
            _table = storedProcedureColumns.Tables[0];
        }
        return _table;
    }
}
DataTable _table;

然后,您可以查询此表格的结构,就像其他答案一样,但它会更通用