Linq to SQL 简单增删改查

用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.
        }
    }
}
 

通过上面示例可以感觉到,运行环境默默在本地维护了一套对象,在数据库端指向的是同一条记录,则在代码这端就是指向同一个实体的引用。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值