5

(我对 Linq to SQL 完全陌生)我正在创建一个与数据库密切合作的 Web 应用程序,我正在寻找最快且连接时间效率最高的模型,并相信 Linq to SQL 就是这样。我正在使用 C#/.Net4/Visual Studio 2010

为简单起见,我有一个包含许多 asp 文本框的 web .aspx 页面。我想通过 Linq 将 SQL 数据中的文本值提供给 SQL 对象。我还有一个名为 DataClasses.dbml 的文件,其中在设计视图中添加了一个表。到目前为止,我的网页代码隐藏中的代码是:

DataClassesDataContext db = new DataClassesDataContext(getConnectionString);

var table = from t in db.MyTable
            where t.PK == 2
            select new { t.col1, t.col2, t.col3};

db.Connection.Open();
db.  // What's the best way of loading the object?
db.Connection.Close();

然后如何访问列值?还是我将它数据绑定到数据表?如果是这样,怎么做?

myTextBox1.Text = table.???col1.value;
4

3 回答 3

16

您无需打开或关闭连接。LinqToSql 为您抽象了这一点。

创建查询后,您可以执行它并使用SingleOrDefault().

using (var db = new DataClassesDataContext(getConnectionString))
{
    var query = from t in db.MyTable
                where t.PK == 2
                select new { t.col1, t.col2, t.col3};
    var myObject = query.SingleOrDefault();
}

您还可以使用 lambda 表示法简化此操作:

using (var db = new DataClassesDataContext(getConnectionString))
{
    var myObject = db.MyTable.SingleOrDefault(t => t.PK == 2 )
}

要访问对象,您可以直接访问列,因为它们已映射到相应的属性:

myTextBox1.Text = myObject.col1;
于 2013-01-10T16:10:59.070 回答
1

常见的方法是调用将执行查询的方法(ToArray、ToList、First、Single 等)或在 foreach 中枚举它。

例如:

var query = from t in db.MyTable
            where t.PK == 2
            select new { t.col1, t.col2, t.col3};

var result = query.ToArray(); // now it contains array of resulting objects

// or enumerate
foreach (var obj in query)
{
    // do stuff with obj
}
于 2013-01-10T16:11:20.780 回答
0

利用

myTextBox1.Text = table.FirstOrDefault().col1.ToString();
于 2013-01-10T16:06:50.910 回答