淺析linq級聯操作
作者:canduecho
本文講解了linq級聯操作,從添加,刪除linq級聯等方面都做了介紹。現在我開始做一個linq級聯操作,給大家參考。
本文講解了linq級聯操作,從添加,刪除linq級聯等方面都做了介紹。
現在我開始做一個linq級聯操作,給大家參考:
1.我首先新建了兩張表一個是category,一個是product.
category表
product表
2.然后添加linq級聯:
- ALTER TABLE product ADD CONSTRAINT [FK_ product _Key] FOREIGN KEY
- (
- catid
- )REFERENCES Category
- (
- catid
- )
- GO
3.代碼:添加的linq級聯代碼是:
- Category_Product_ContextDataContext cpcontext =
- new Category_Product_ContextDataContext
- (System.Configuration.ConfigurationManager.ConnectionStrings
- ["TestConnectionString"].ToString());
- // 級聯添加
- Category cat=new Category()
- ...{
- Catid =1005,
- CatName = "設計",
- CatDescription = "好多設計 "
- };
- Product p1 = new Product()
- ...{
- ProductName = "平面設計",
- ProductDescripton = "設計大",
- Category=cat
- };
- Product p2 = new Product()
- ...{
- ProductName = "立體設計",
- ProductDescripton = "新電腦",
- Category = cat
- };
- Product p3 = new Product()
- ...{
- ProductName = " 室內設計",
- ProductDescripton = " 室內設計林",
- Category = cat
- };
- Product p4 = new Product()
- ...{
- ProductName = "產品設計",
- ProductDescripton = "林",
- Category = cat
- };
- Product p5 = new Product()
- ...{
- ProductName = "建筑設計",
- ProductDescripton = "在",
- Category = cat
- };
- cpcontext.Categories.InsertOnSubmit(cat);
- cpcontext.SubmitChanges();
刪除的linq級聯代碼:
刪除的原則是:先刪除從表的再刪除主表的
- Category_Product_ContextDataContext cpcontext =
- new Category_Product_ContextDataContext
- (System.Configuration.ConfigurationManager.ConnectionStrings
- ["TestConnectionString"].ToString());
- Category singlecats = cpcontext.Categories.Single
- (p => p.Catid == 1004);
- foreach (Product p in cpcontext.Products.Where(p => p.CatId == 1004))
- //刪除從表
- ...{
- cpcontext.Products.DeleteOnSubmit(p);
- }
- cpcontext.Categories.DeleteOnSubmit(singlecats);//刪除主表
- cpcontext.SubmitChanges();
以上就是對linq級聯操作的簡單介紹。
【編輯推薦】
責任編輯:阡陌
來源:
CSDN