是否有一个开关来获取SQL Server的表的字段的默认值作为FormView / DetailsView的TextBox的默认值?

时间:2012-05-12 12:01:01

标签: c# asp.net sql-server

我正在使用SQL Server 2008 R2和VS2010 C#ASP.NET 4

FormView和DetailsView在插入模式下出现空文本框。

我希望那些TextBoxes能够反映SQL Server上各列默认值的默认值。

有一种简单的方法吗?


编辑:(示例)

问题:

enter image description here

表格:

CREATE TABLE [dbo].[SampleTable](
    [PKColumn1] [int] IDENTITY(1,1) NOT NULL PRIMARY KEY CLUSTERED,
    [IntColumn2] [int] NOT NULL DEFAULT (12),
    [nvarcharColumn3] [nvarchar](50) NOT NULL DEFAULT (N'bla bla'),
    [IntColumn4NoDefault] [int] NULL)

aspx标记:

<asp:DetailsView ID="DetailsView1" runat="server" Height="50px" Width="125px" 
            AutoGenerateRows="False" DataKeyNames="PKColumn1" DataSourceID="SqlDataSource1" 
            DefaultMode="Insert">
            <Fields>
                <asp:BoundField DataField="PKColumn1" HeaderText="PKColumn1" InsertVisible="False" ReadOnly="True" SortExpression="PKColumn1" />
                <asp:BoundField DataField="IntColumn2" HeaderText="IntColumn2" SortExpression="IntColumn2" />
                <asp:BoundField DataField="nvarcharColumn3" HeaderText="nvarcharColumn3" SortExpression="nvarcharColumn3" />
                <asp:BoundField DataField="IntColumn4NoDefault" 
                    HeaderText="IntColumn4NoDefault" SortExpression="IntColumn4NoDefault" />
                <asp:CommandField ShowInsertButton="True" />
            </Fields>
        </asp:DetailsView>

        <asp:SqlDataSource ID="SqlDataSource1" runat="server" 
            ConnectionString="<%$ ConnectionStrings:dbConnectionString %>" 
            InsertCommand="INSERT INTO [SampleTable] ([IntColumn2], [nvarcharColumn3], [IntColumn4NoDefault]) VALUES (@IntColumn2, @nvarcharColumn3, @IntColumn4NoDefault)" 
            SelectCommand="SELECT * FROM [SampleTable]">
            <InsertParameters>
                <asp:Parameter Name="IntColumn2" Type="Int32" />
                <asp:Parameter Name="nvarcharColumn3" Type="String" />
                <asp:Parameter Name="IntColumn4NoDefault" Type="Int32" />
            </InsertParameters>
        </asp:SqlDataSource>

C#代码中没有任何内容。

1 个答案:

答案 0 :(得分:1)

是的,有......

select  c.name, definition 
from    sys.default_constraints dc 
join    sys.columns c 
on      c.object_id = dc.parent_object_id 
        and c.column_id = dc.parent_column_id 
where   parent_object_id = object_id('mytable') 

获得结果集后,您应该拥有列名和默认值。如果每个具有默认值的列与文本框对应(1:1),只需将Repeater添加到表单/ webform并绑定&#39;定义&#39;到Text属性。由于输出中添加了括号,您可能需要稍微按下数据,但可能正则表达式或简单替换可能会有效。