Linq to SQL 简单增删改查
2014-08-31 12:45
387 查看
用Linq大大减少了对数据库的一般操作所需的编码量。
运行下面事例之前,首先建一个叫做Alien的数据库表。
CREATE TABLE [dbo].[Aliens](
[Id] [int] IDENTITY(1,1) NOT NULL primary key,
[Name] [nchar](10) NULL,
)
建一个console项目,在项目里添加一个Linq To Sql类文件(.dbml以及两个附属文件),把Alien表从服务器资源管理器拖进来。然后就可以运行下面的代码了:
示例代码
using System;
using System.Linq;
namespace LearnLinqToSql
{
class Program
{
static void Main(string[] args)
{
ForLearnDataContext db = new ForLearnDataContext();
db.Log = Console.Out;
// Insert
Alien et = new Alien { Name = "ET" };
db.Alien.InsertOnSubmit(et);
db.SubmitChanges();
// Update
Alien toChange = db.Alien.Where(a => a.Name == "ET").First();
toChange.Name = "DC";
db.SubmitChanges();
// Delete
Alien dc = db.Alien.Where(a => a.Name == "DC").First();
db.Alien.DeleteOnSubmit(et);
db.SubmitChanges();
Console.WriteLine(et.GetHashCode());
Console.WriteLine(toChange.GetHashCode());
Console.WriteLine(dc.GetHashCode());
db.Alien.InsertOnSubmit(et); // Error: Cannot add an entity that already exists.
}
}
}
通过上面示例可以感觉到,运行环境默默在本地维护了一套对象,在数据库端指向的是同一条记录,则在代码这端就是指向同一个实体的引用。
运行下面事例之前,首先建一个叫做Alien的数据库表。
CREATE TABLE [dbo].[Aliens](
[Id] [int] IDENTITY(1,1) NOT NULL primary key,
[Name] [nchar](10) NULL,
)
建一个console项目,在项目里添加一个Linq To Sql类文件(.dbml以及两个附属文件),把Alien表从服务器资源管理器拖进来。然后就可以运行下面的代码了:
示例代码
using System;
using System.Linq;
namespace LearnLinqToSql
{
class Program
{
static void Main(string[] args)
{
ForLearnDataContext db = new ForLearnDataContext();
db.Log = Console.Out;
// Insert
Alien et = new Alien { Name = "ET" };
db.Alien.InsertOnSubmit(et);
db.SubmitChanges();
// Update
Alien toChange = db.Alien.Where(a => a.Name == "ET").First();
toChange.Name = "DC";
db.SubmitChanges();
// Delete
Alien dc = db.Alien.Where(a => a.Name == "DC").First();
db.Alien.DeleteOnSubmit(et);
db.SubmitChanges();
Console.WriteLine(et.GetHashCode());
Console.WriteLine(toChange.GetHashCode());
Console.WriteLine(dc.GetHashCode());
db.Alien.InsertOnSubmit(et); // Error: Cannot add an entity that already exists.
}
}
}
通过上面示例可以感觉到,运行环境默默在本地维护了一套对象,在数据库端指向的是同一条记录,则在代码这端就是指向同一个实体的引用。
相关文章推荐
- linq to sql 简单的增删改查例子。
- 简单的linq to sql 的例子 ,实现了增删改查。
- Linq to SQL 简单增删改查
- LINQ to SQL 自学笔记(1)-最简单的应用
- ORM, Linq to sql增删改查
- Linq To Sql 简单的单表批量删除
- (原创)LINQ To SQL简单入门
- 简单的linq to sql
- 一个简单的LINQ TO SQL的三层架构的例子
- LINQ to SQL 在 Visual Studio 2008 中的简单应用
- Linq To Sql 简单的单表批量删除
- Linq学习笔记二(Linq to sql 增删改查)
- LINQ学习(九):LINQ to SQL简单应用
- Linq to sql 增删改查
- LINQ to SQL 在 Visual Studio 2008 中的简单应用
- Linq to sql 简单性能差异指引 (转)
- Linq to sql之简单的分页
- LINQ to SQL 在 Visual Studio 2008 中的简单应用
- linq to sql 增删改查入门编[linq学习笔记一]
- LINQ to SQL(3):增删改查