我正在学习T4模板,我在互联网上获得的所有示例都是关于使用表格生成代码。我想使用存储过程结果列来生成自动UI,是否可能?或者我必须为同一个查询创建视图?在这种情况下,如何从视图中读取?
提前致谢。
答案 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;
然后,您可以查询此表格的结构,就像其他答案一样,但它会更通用