/*********************Insert,delete,update,attach操作练习**********************************/
            //简单插入形式
            var student = new T_Student
            {
                stuNumber = "20091777",
                stuName = "张航",
                stuAge = 23,
                stuSex = "男"
            };

ctx.T_Student.InsertOnSubmit(student);
            ctx.SubmitChanges();
            //一对多形式,或者多对多形式,需要按照主外健关系依次插入

var student1 = new T_Student
            {
                stuNumber = "2009177",
                stuName = "谢亮",
                stuAge = 23,
                stuSex = "男"
            };
            var score1 = new T_Score
            {
                stuNumber = student1.stuNumber,
                courceNumber = "001",
                score = 78
            };
            var score2 = new T_Score
            {
                stuNumber = student1.stuNumber,
                courceNumber = "002",
                score = 78
            };

     ctx.T_Student.InsertOnSubmit(student1);
            ctx.T_Score.InsertOnSubmit(score1);
            ctx.T_Score.InsertOnSubmit(score2);
            ctx.SubmitChanges();

//更爱张航的年龄为21,这种涉及到单项或者更改项很少的,可以用下面的方式更改

var list = ctx.T_Student.First(s=>s.stuName=="张航");
            list.stuAge = 21;
            ctx.T_Student.InsertOnSubmit(list);
            ctx.SubmitChanges();

//让学生表中各个学生的年龄加一岁
            var list1 = from t in ctx.T_Student
                         select t;
            foreach (var item in list1)
            {
                item.stuAge = item.stuAge + 1;
            }
            ctx.T_Student.InsertAllOnSubmit(list1);
            ctx.SubmitChanges();

//删除学号为2091721,课程编号为002的学生
            var list2 = ctx.T_Score.First(s => s.stuNumber == "2091721"&&s.courceNumber=="002");
            ctx.T_Score.DeleteOnSubmit(list2);
            ctx.SubmitChanges();
            //删除学号为黄阳的个人信息及分数信息
            var list3 = ctx.T_Student.First(s=>s.stuName=="黄阳");
            var list4 = from a in ctx.T_Score
                        where a.T_Student.stuName == "黄阳"
                        select a;
            foreach (var item in list4)
            {
                ctx.T_Score.DeleteOnSubmit(item);
            }
            ctx.T_Student.DeleteOnSubmit(list3);
            ctx.SubmitChanges();
            //还可以推理删除,推理删除需要用Remove方法。由于表的设计不是很完善,这里就不给演示了
            
            //对于在不同的上下文间,需要使用attach方法进行更新,如在一个上下文中查出一个叫黄阳的学生和它的各科成绩,在另一个上下文中将其年龄改为19,将其所有学科科目成绩改为33分
            T_Student student2;
            List<T_Score> listScore = new List<T_Score>();
            using (DB_StudentDataContext ctx1 = new DB_StudentDataContext())
            {
                var stu = ctx1.T_Student.First(s=>s.stuName=="黄阳");
                student2 = new T_Student {
                    stuNumber=stu.stuNumber,
                    stuName=stu.stuName,
                    stuAge=stu.stuAge,
                    stuSex=stu.stuSex
                };

var scores = from k in ctx1.T_Score
                             where k.T_Student.stuName == "黄阳"
                             select k;
                foreach (var item in scores)
                {
                    listScore.Add(item);
                }
            }

ctx.T_Student.Attach(student2);
            student.stuSex = "19";

ctx.T_Score.AttachAll(listScore);
            foreach (var item in listScore)
            {
                item.score = 33;
            }

ctx.SubmitChanges();

//使用attach进行删除,更改,插入

T_Student student3 = null;
            using (DB_StudentDataContext ctx2 = new DB_StudentDataContext())
            {
                DataLoadOptions dlo = new DataLoadOptions();
                dlo.LoadWith<T_Student>(s => s.T_Score);
                ctx2.DeferredLoadingEnabled = false;
                student3 = ctx2.T_Student.First(s=>s.stuName=="黄阳");
            }
            T_Score scores1 = student3.T_Score.First();
            T_Score scores2 = student3.T_Score.First(s => Convert.ToInt32(s.stuNumber) > Convert.ToInt32(scores1.stuNumber));

using (DB_StudentDataContext ctx3 = new DB_StudentDataContext())
            {
                ctx3.T_Student.Attach(student3);
                ctx3.T_Score.AttachAll(student3.T_Score.ToList());
                scores1.score = 80;
                student3.T_Score.Remove(scores2);

T_Score score3 = new T_Score {
                    stuNumber = "2009177",
                    courceNumber = "003",
                    score=88
                };
                student3.T_Score.Add(score3);

ctx3.SubmitChanges();

Linq无聊练习系列7----Insert,delete,update,attach操作练习的更多相关文章

  1. 带有OUTPUT的INSERT,DELETE,UPDATE

    原文地址:http://blog.sina.com.cn/s/blog_71460d950100nld2.html OUTPUT是SQL SERVER2005的新特性.可以从数据修改语句中返回输出.可 ...

  2. Use Select To Generate Any Insert/Delete/Update Statement

    If you don't have the permission to generate script according to an existing db, but you have the re ...

  3. sqlserver触发器insert,delete,update

    Create Trigger [dbo].[upemployee_kefyu_sale] on [dbo].[employee] for update as if update(FullName) b ...

  4. sql server 带有OUTPUT的INSERT,DELETE,UPDATE

    原文:sql server 带有OUTPUT的INSERT,DELETE,UPDATE OUTPUT是SQL SERVER2005的新特性.可以从数据修改语句中返回输出.可以看作是"返回结果 ...

  5. MySQL进阶10--DML数据操纵预言: insert/delete/update --多表连接修改/.多表连接删除/多表连接查询-- truncate 和 delete的区别

    /* DML -- 数据操纵预言: insert/delete/update */ #一: 插入语句 /* 语法1: insert into 表名(列名,..,列名....) values(值1,值2 ...

  6. 触发器内insert,delete,update判断执行不同的内容

    create trigger tr_aon afor insert,update,delere asbegin IF EXISTS(SELECT 1 FROM inserted) AND NOT EX ...

  7. MyBatis insert/delete/update 的返回值

    insert,返回值是:新插入行的主键(primary key):需要包含<selectKey>语句,才会返回主键,否则返回值为null. <insert id="inse ...

  8. Linq无聊练习系列8---开放式并发事务,null和 DateTime,string操作练习

    /*********************开放式并发事务,null和 DateTime,string操作练习**********************************/ //所谓并发,就是 ...

  9. Linq无聊练习系列1--where练习

    linq主要有3种,linq to sql,linq to XML,Linq to Object linq to sql. 这里没有通过相应的类,生成相应的数据库中的表.没有用流行的编码优先. 只是为 ...

随机推荐

  1. Visual studio 2013 bug:visual studio no editoroptiondefinition export found for the given option nam

    昨天VS 2013打开项目,双击cs当文件,下面出现bug. Google没有理由.最后,在刚刚好清理C磁盘缓存用户文件夹. 然后就OK了. 详细的路径是:C:\Users\{当前用户}\AppDat ...

  2. VB.NET与C# 语法show差异

    学习VB.NET后发现,VB.NET与C#的语法基本的不同在两个部分,这两部分搞通了,那就游刃有余,迎刃而解了. 现将其对照总结例如以下: 一.实体部分 (与VB相比.在C#和VB.NET中,实体的使 ...

  3. 刚刚回归的开始菜单 Windows 10全面体验

    北京时间2014年10月1日凌晨,微软就在旧金山召开新品公布会,对外展示了自己新一代操作系统Windows 10,覆盖了包含手机.平板.台式机以及Xbox One在内的全部平台.尽管微软此次公布的不过 ...

  4. C#将Excel数据导入数据库(MySQL或Sql Server)

    最近一直很忙,很久没写博客了.今天给大家讲解一下如何用C#将Excel数据导入Excel,同时在文章最后附上如何用sqlserver和mysql工具导入数据. 导入过程大致分为两步: 1.将excel ...

  5. 【翻译】C#和.NET核心快速参考

    原文:[翻译]C#和.NET核心快速参考 PS:在网上看到的一篇C#总结,英文的,总结的还可以,都是基础知识,翻译给大家学习.文章结尾有英文原版.发布地址:http://www.cnblogs.com ...

  6. C# Parse和Convert的区别分析

    原文:C# Parse和Convert的区别分析 大家都知道在进行类型转换的时候有连个方法供我们使用就是Convert.to和*.Parse,但是疑问就是什么时候用C 什么时候用P 通俗的解释大家都知 ...

  7. js 利用iframe和location.hash跨域解决的方法,java图片上传回调JS函数跨域

    奶奶的:折腾了我二天,最终攻克了!网上有非常多样例. 但跟我的都不太一样,费话不多说了,上图   上代码: IE ,firefix,chrome 測试通过 js :这个主页面,部分代码, functi ...

  8. Coreseek:索引和检测的第二步骤施工

    1,非常索引easy,代码行 g:/service/coreseek/bin/indexer -c g:/service/coreseek/etc/csft_mysql.conf   person 在 ...

  9. Codeforces 363A Soroban

    模拟算盘 #include<bits/stdc++.h> using namespace std; int main() { char s[20]; scanf("%s" ...

  10. 小结php中几种网页跳转

    1.使用网页中<a href=.....></a>实现跳转: 2.<form action="php_request2.php" method=&qu ...