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,"女")
};