【问题标题】:Get values from DataTable without data binding to UI controls?在没有数据绑定到 UI 控件的情况下从 DataTable 获取值?
【发布时间】:2012-01-23 15:01:13
【问题描述】:

我总是从数据库中直接获取值到这样的控件:

代码隐藏:

DataTable table = GetUserInfo();

UserInfo.DataSource = table;
UserInfo.DataBind();

string FirstName = lblFirstName.Text;
string LastName = lblLastName.Text;
DateTime BecomeAMember = DateTime.Parse(lblBecomeAMember.Text);

标记:

<asp:Label ID="lblCity" runat="server" Text='<%# Eval("FirstName") %>' />
<asp:Label ID="lblLastName" runat="server" Text='<%# Eval("LastName") %>' />
<asp:Label ID="lblBecomeAMember" runat="server" Text='<%# Eval("BecomeAMember", "{0:dd MMM yyy) %>' />

必须有一种方法可以在代码隐藏中使用数据而不将其放在标签上,然后使用String text = label.Text;

我需要来自BecomeAMember 的分钟和小时数,并且我不想将另一个Label 与完整的DateTime 一起使用并使其不可见。很高兴知道如何获得其他值。

【问题讨论】:

  • 由于您的控件设置了 runat=server,您不能只将值分配给后面代码中的标签并相应地设置格式吗?

标签: c# asp.net .net data-binding datatable


【解决方案1】:

是的,您可以直接调查DataTable 中保存的数据。

DataTable can be made into an IEnumerable, and can be queried. 在你的情况下:

var datetimes = table.AsEnumerable().Select(x => x.Field<DateTime>("BecomeAMember"));

如果你真的只希望有一行,你可以这样做:

var dt = table.AsEnumerable().Select(x => x.Field<DateTime>("BecomeAMember")).Single();

或:

var dt = (DateTime) table.Rows[0]["BecomeAMember"];

然后使用带有格式字符串的ToString 格式化dt

【讨论】:

    【解决方案2】:

    您可以使用DataTable 方法直接从table 对象中读取值。

    例如,

    string firstName = table.Rows[0]["FirstName"].ToString();
    

    foreach (DataRow row in table.Rows)
    {
        //
    }
    

    或者使用 Select() 方法在指定字段上进行搜索。

    DataRow[] rows = table.Select("column1='value1'");
    

    【讨论】:

      猜你喜欢
      • 2010-11-11
      • 1970-01-01
      • 2013-09-18
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多