/*********************开放式并发事务,null和 DateTime,string操作练习**********************************/

//所谓并发,就是两个或更多用户同时尝试更新同一数据库行的情形。并发冲突就是两个或更多用户同时尝试向一行的一列或多列提交冲突值的情形。
            //LINQ to SQL 支持三种事务模型,分别是显式本地事务:调用 SubmitChanges 时,如果 Transaction 属性设置为事务,则在同一事务的上下文中执行 SubmitChanges 调用。成功执行事务后,要由您来提交或回滚事务。与事务对应的连接必须与用于构造 DataContext 的连接匹配。如果使用其他连接,则会引发异常。
            //显式可分发事务:可以在当前 Transaction 的作用域中调用 LINQ to SQL API(包括但不限于 SubmitChanges)。LINQ to SQL 检测到调用是在事务的作用域内,因而不会创建新的事务。在这种情况下,<token>vbtecdlinq</token> 还会避免关闭连接。您可以在此类事务的上下文中执行查询和 SubmitChanges 操作。
            //隐式事务:当您调用 SubmitChanges 时,LINQ to SQL 会检查此调用是否在 Transaction 的作用域内或者 Transaction 属性是否设置为由用户启动的本地事务。如果这两个事务它均未找到,则 LINQ to SQL 启动本地事务,并使用此事务执行所生成的 SQL 命令。当所有 SQL 命令均已成功执行完毕时,LINQ to SQL 提交本地事务并返回。

// 并发冲突:如想更改“黄阳”的年龄为13,另外一个用户想更改为23
            var student1 = ctx.T_Student.First(s=>s.stuName=="黄阳");
            student1.stuAge = 13;

DB_StudentDataContext ctx1 = new DB_StudentDataContext();
            var student2 = ctx1.T_Student.First(s=>s.stuName=="黄阳");
            student2.stuAge = 23;

ctx.SubmitChanges();
            
            //在Linq to SQL中,有三种方法创建事务:

// 如果没有指定任何事务,那么当调用SubmitChanges方法时,DataContext会默认创建一个事务。
            //使用TransactionScope创建轻量级事务(需要引用 System.Transactions命名空间)
             //给DataContext的Transaction属性指定事务

//解决并发冲突(隐式事务)

try {

var student3 = ctx.T_Student.First(s=>s.stuName=="黄阳");
                student3.stuAge = 23;
                var student4 = ctx.T_Student.First(s => s.stuName == "黄阳");
                student4.stuAge = -1;
                ctx.SubmitChanges();

}
            catch {
            //进行处理
            }

//显示事务进行处理

using (TransactionScope scope = new TransactionScope())
            {
                try {
                    var student5 = ctx.T_Student.First(s => s.stuName == "黄阳");
                    student5.stuAge = 23;
                    var student6 = ctx.T_Student.First(s => s.stuName == "黄阳");
                    student6.stuAge = -1;
                    ctx.SubmitChanges();
                }
                catch {
                    //进行异常处理
                }
            }

// null操作:查询没有参加课程名为微机原理的所有学生
            var students = from s in ctx.T_Score
                           where s.T_Cource.courceName == "微机原理" && s.T_Student.stuNumber == null
                           select new
                           {
                               学生 = s.T_Student.stuNumber
                           };

// HasValue只能对非引用外键起作用
            var students0 = from s in ctx.T_Score
                           where s.T_Cource.courceName == "微机原理" && !s.score.HasValue
                           select new
                           {
                               学生 = s.T_Student.stuNumber
                           };
            var scores = from s in ctx.T_Score
                         where s.score.HasValue
                         select new {
                          studentNumber = s.stuNumber,
                          studentScore = s.score.Value,
                          stuCourece = s.courceNumber
                         };

//获取1989年生的孩子,由于数据库设计的缺陷,没有设置生日,设置的时年龄,其实这样并不合理,应该设置为出生年月日,这样能够更好的利用日期函数进行处理,如dateTime.Value.Year,dateTime.Value.Month,dateTime.Value.Day

//对string进行操作
            //连接操作,如对学生信息进行整理
            var studnetInfo = from s in ctx.T_Student
                              select new
                              {
                                  studentNumber = s.stuNumber,
                                  studentInfomation = s.stuSex + "," + s.stuName
                              };

//查询姓名字数为两个字的个数
            var userName = from s in ctx.T_Student
                           where s.stuName.Length == 2
                           select s;
            //查询名字为黄的学生

var students2 = from s in ctx.T_Student
                            where s.stuName.Contains("黄")
                            select s;

//查询每个人的名字里边出现阳的位置
            var studnets3 = from s in ctx.T_Student
                            select new {
                                username= s.stuName,
                                place = s.stuName.IndexOf("阳")
                            };
            //查询姓名以黄开头的人的信息
            var students4 = from s in ctx.T_Student
                           where s.stuName.StartsWith("黄")
                           select s;
            //查询姓名以阳结尾的人信息
            var students5 = from s in ctx.T_Student
                            where s.stuName.EndsWith("阳")
                            select s;
            //查询姓名为黄阳的学生的姓名第二个字
            var students6 = from s in ctx.T_Student
                            where s.stuName == "黄阳"
                            select s.stuName.Substring(2);

//查询姓名开始和结束为黄阳的学生信息
            var studnts7 = from s in ctx.T_Student
                           where s.stuName.Substring(0, 2) == "黄阳"
                           select s;
            //如果数据库里设置了英文信息,可以将其转化为大写或者小写,toUpper,toLower
            
            //可以查询姓名的姓,并移除前边和后边的空格

var students8 = from s in ctx.T_Student
                            select s.stuName.Substring(0, 1).Trim();

//在姓名为黄的后边加入一个冒号:
            var students9 = from s in ctx.T_Student
                            where s.stuName.Substring(0, 1) == "黄"
                            select s.stuName.Insert(1, ":");
            //在姓名为黄的学生姓名里,移除姓后边的字
            var students10 = from s in ctx.T_Student
                             where s.stuName.Substring(0, 1) == "黄"
                             select s.stuName.Remove(1);
            //在姓名为黄的学生姓名里,移除姓后边的第一个字
            var students11 = from s in ctx.T_Student
                             where s.stuName.Substring(0, 1) == "黄"
                             select s.stuName.Remove(1,2);
            //将性别为男的的学生全部把性别替换为女的
            var students12 = from s in ctx.T_Student
                             where s.stuSex=="男"
                             select new
                             {
                                 stuName = s.stuName,
                                 stuNumber=s.stuNumber,
                                 stuSex = s.stuSex.Replace(s.stuSex,"女")
                             };

Linq无聊练习系列8---开放式并发事务,null和 DateTime,string操作练习的更多相关文章

  1. Linq无聊练习系列6--Any/All/Contains/Concat/Union/Intersect/Except/take/skip/SqlMethods操作练习

    /*********************Any/All/Contains/Concat/Union/Intersect/Except/take/skip/SqlMethods操作练习******* ...

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

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

  3. Linq无聊练习系列7----Insert,delete,update,attach操作练习

    /*********************Insert,delete,update,attach操作练习**********************************/            ...

  4. Linq无聊练习系列5--OrderBy ,Groupby练习

    /**************OrderBy ,Groupby练习*******************/                       //按学生的总分数按降序排列排序         ...

  5. Linq无聊练习系列4--join练习

    /**************join 练习*******************/            //对于1对多关系            var list =from c in ctx.T ...

  6. Linq无聊练习系列3--聚合函数练习

    /**************聚合函数 练习*******************/            //求学生的总数量            var list = ctx.T_Student. ...

  7. Linq无聊练习系列2--select/distinct练习

    void dataBindByWhere()        { /**************select/distinct 练习*******************/            //获 ...

  8. Code First开发系列之管理并发和事务

    返回<8天掌握EF的Code First开发>总目录 本篇目录 理解并发 理解积极并发 理解消极并发 使用EF实现积极并发 EF的默认并发 设计处理字段级别的并发应用 实现RowVersi ...

  9. EF中的开放式并发(EF基础系列--28)

    好久没更新EF这个系列了,现在又重新开始. 这次学习,开放式并发.首先拿出数据库脚本: 说明一下,这个数据库脚本是之前的章节中稍作修改的: USE [SchoolDB] GO /****** Obje ...

随机推荐

  1. 2014在百度之星资格赛的第四个冠军Labyrinth

    Problem Description 熊度仅仅是一种冒险的熊,一个偶然落入一个m*n迷宫矩阵,能从矩阵左上角第一个方格開始走,仅仅有走到右上角的第一个格子才算走出迷宫.每一次仅仅能走一格,且仅仅能向 ...

  2. 挑逗B少年搞计划10 假设你是愿意用我的心脏层剥离一层~

        这些天都非常推迟考试啊.然后,学校已安排一周培训,是的.在延迟学习,大狼医院我真的是正常水平.     幸好我们周六周日不让放假了,不然预计进度直接就停了.这两天也是抽出了时间把敲了一下三层的 ...

  3. Jquery动态插入table行

    想在一个<table id="table1"></table>标签中动态的插入行,在jquery中可以这样做: $("#table1") ...

  4. warning: shared library text segment is not shareable

    warning: shared library text segment is not shareable error: treating warnings as errors 近期在调试一个Gsen ...

  5. Android checkCallingPermission()方法返回值问题

    Android开发检查权限时,发现调用checkCallingPermission()总是返回值-1,而Binder.getCallingPid() == Process.myPid()又总是返回tr ...

  6. ASP.NET 5:依赖注入

    ASP.NET 5:依赖注入 1.背景 如果某个具体的(或类)对象被客户程序所依赖,通常把它们抽象成抽象类或接口.简单说,客户程序摆脱所依赖的具体类型,称之为面向接口编程. 那么问题来了?如何选择客户 ...

  7. android网络操作使用汇总(http)

    Android是作为智能手机的操作系统,我们开发的应用,大多数也都须要连接网络,通过网络发送数据.获取数据,因此作为一个应用开发人员必须熟悉怎么进行网络訪问与连接. 通常android中进行网络连接通 ...

  8. linux 在系统启动过程

    从学习<鸟哥linux私人厨房> 用于在计算机系统启动,计算机硬件和软件由(它包含的操作系统软件)包括.对于操作系统在同一台计算机硬件方面的表现,该系统配备有硬件是公用,不同的系统是 的操 ...

  9. Jmeter性能测试

    Jmeter性能测试 入门 Jmeter是一款优秀的开源测试工具, 是每个资深测试工程师,必须掌握的测试工具,熟练使用Jmeter能大大提高工作效率. 熟练使用Jmeter后, 能用Jmeter搞定的 ...

  10. Math.random引发的骗术,绝对是用随机数骗前端妹纸的最佳方法

    我觉得今天我运气特好,今天我们来赌一赌,我们来搞个随机数,Math.floor(Math.random() * 10),如果这个数等于0到7,这个月的饭,我全请了,如果是8或9,你就请一个礼拜成不?于 ...