/*********************开放式并发事务,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. unity 编辑器和插件生产(四.2)

    上次 我们告诉编辑器制作,如何将图像加载到现场,如今 我们要告诉下.怎么样 制造UIButton以及UIimage交换. 阿土. 进入专题. 首先,我们要明白 unity机制.button属性等. 首 ...

  2. Matrix (二维树状数组)

    Description Given an N*N matrix A, whose elements are either 0 or 1. A[i, j] means the number in the ...

  3. Android一些解决方案内存问题(一)

    通常我们遇到内存问题时,,解决方案一般有以下的例子: 1.做一些处理上的内存引用,经常使用软引用.加强引用.弱引用: 2.加载在内存中的照片时,它可以处理直接在内存,例如:压缩边界. 3.内存的动态恢 ...

  4. Facebook的ATOM Editor的底层Electron

    Facebook的ATOM Editor的底层Electron 开源牛人 zcbenz 事情是这样的,微软推出了Visual Studio Code,我很好奇他怎么做跨平台的,所以就找找资料,在他的网 ...

  5. 【Leetcode】Sort List (Sorting)

    这个问题需要与归并排序排两个名单,基本思路分为切割与合并 合并后的代码Merge Two Sorted List里已经讲得非常清楚了. 所以这里直接给出代码. public ListNode merg ...

  6. openSUSE 安装

    https://lug.ustc.edu.cn/sites/opensuse-guide/installation.php 开始 1. 简介2. 改用 GNU/Linux3. 获取 openSUSE4 ...

  7. Petroglyph访问:中间件游戏

    Xsolla有幸与Petroglyph的总裁及创始人Michael Legg进行了对话. 这是及时战略游戏中对主要一家公司. 由前Westwood的员工 创办,还设计了一块新的RTS游戏-Grey G ...

  8. Asp.net实现URL重写

    原文:Asp.net实现URL重写 [概述] URL重写就是首先获得一个进入的URL请求然后把它重新写成网站可以处理的另一个URL的过程.重写URL是非常有用的一个功能,因为它可以让你提高搜索引擎阅读 ...

  9. .net mvc mssql easyui treegrid

    效果图 数据图   可以看到 这里是根据 MenuNo 来 分级别的,支持 无限极,第一级是 01 ,第二级就是 01XX ,第三级 就是 01XXOO.类似 id.pid ,Ztree 里面 也是这 ...

  10. 如何把一个c语言程序做成windows服务开机自启动

    原文:如何把一个c语言程序做成windows服务开机自启动 目前写的程序是一个用c语言实现socket侦听的,那么如何把这个程序做成开机自启动呢? 我们是通过vs6.0,编译后生成了.exe文件,然后 ...