Linq无聊练习系列8---开放式并发事务,null和 DateTime,string操作练习
/*********************开放式并发事务,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操作练习的更多相关文章
- Linq无聊练习系列6--Any/All/Contains/Concat/Union/Intersect/Except/take/skip/SqlMethods操作练习
/*********************Any/All/Contains/Concat/Union/Intersect/Except/take/skip/SqlMethods操作练习******* ...
- Linq无聊练习系列1--where练习
linq主要有3种,linq to sql,linq to XML,Linq to Object linq to sql. 这里没有通过相应的类,生成相应的数据库中的表.没有用流行的编码优先. 只是为 ...
- Linq无聊练习系列7----Insert,delete,update,attach操作练习
/*********************Insert,delete,update,attach操作练习**********************************/ ...
- Linq无聊练习系列5--OrderBy ,Groupby练习
/**************OrderBy ,Groupby练习*******************/ //按学生的总分数按降序排列排序 ...
- Linq无聊练习系列4--join练习
/**************join 练习*******************/ //对于1对多关系 var list =from c in ctx.T ...
- Linq无聊练习系列3--聚合函数练习
/**************聚合函数 练习*******************/ //求学生的总数量 var list = ctx.T_Student. ...
- Linq无聊练习系列2--select/distinct练习
void dataBindByWhere() { /**************select/distinct 练习*******************/ //获 ...
- Code First开发系列之管理并发和事务
返回<8天掌握EF的Code First开发>总目录 本篇目录 理解并发 理解积极并发 理解消极并发 使用EF实现积极并发 EF的默认并发 设计处理字段级别的并发应用 实现RowVersi ...
- EF中的开放式并发(EF基础系列--28)
好久没更新EF这个系列了,现在又重新开始. 这次学习,开放式并发.首先拿出数据库脚本: 说明一下,这个数据库脚本是之前的章节中稍作修改的: USE [SchoolDB] GO /****** Obje ...
随机推荐
- Java中间(三十五)-----Java详细设置(一个):请指定初始容量设置
集合是我们在Java编程中使用很广泛的,它就像大海,海纳百川,像万能容器,盛装万物.并且这个大海,万能容器还能够无限变大(假设条件同意). 当这个海.容器的量变得很大的时候,它的初始容量就会显得很重要 ...
- LeetCode——Linked List Cycle II
Given a linked list, return the node where the cycle begins. If there is no cycle, return null. Foll ...
- 基于PHP的crontab定时任务管理
BY JENNER · 2014年11月10日· 阅读次数:6 linux的crontab一直是server运维.业务开展的利器.但当定时任务增多时,管理和迁移都变得非常麻烦,并且easy出问题.以下 ...
- 网络资源(9) - TDD视频
2014_08_26 http://v.youku.com/v_show/id_XMzI4Mzk1MjQ4.html TDD测试驱动开发
- 浅谈JavaScript中的字符串操作
我想,最为一名开发人员,最实际开发过程中,任何一门语言在开发实际的项目的过程中,都是逃不开字符串的操作的下面笔者就自己日常开发过程中所用到的一些字符串的操作方法做一些陈述和总结,当然,如若读者觉得 ...
- django csrf_token生成
django模板中生成csrf_token的不同方式 系统环境 CENTOS 6.4 python 2.7.6 django 1.7.1 当post提交表单的的时候,是需要 csrf_token的, ...
- WeakReference and WeakHashMap
弱引用通过WeakReference类实现,弱引用和软引用很像,但弱引用的引用级别更低.对于只有弱引用的对象而言,当系统垃圾回收机制运行时,不管系统北村是否足够,总会回收该对象所占用的内存.当然,并不 ...
- 【UVA】580-Critical Mass
依据递推公式计算,须要打表不然可能会超时. #include<cstdio> #include<cstring> #include<iostream> #inclu ...
- POJ 2109 :Power of Cryptography
Power of Cryptography Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 18258 Accepted: ...
- JDBC加载过程
jdbc载入的过程如图所看到的. 桥接模式请參照:设计模式:桥接模式 blog目的:与图说话 版权声明:本文博客原创文章,博客,未经同意,不得转载.