linq 初步认识
linq to sql 类
介绍:
linq如果不能用的话 重装一下vs就好了
LINQ,语言集成查询(Language Integrated Query)是一组用于c#和Visual Basic语言的扩展。它允许编写C#或者Visual Basic代码以查询数据库相同的方式操作内存数据。
是一种高集成化的数据库访问技术。
他与ado.net区别就是 ado.net是最基础的 linq是最高级的;
实用linq 不会用数据库,sql语句不会写也可以访问数据库;
改变的是数据访问层;
实用:
先做一个table 共7列,再放一个Repeater循环绑定

准备工作完成后,在解决方案里新建项,找到linq to sql
文件格式是.dbml
命名使默认名不懂,想要操作那个数据库就把数据库名写在前面。
创建时提示这个类必须放在名为app_code的文件夹里,确认自动添加;
创建完成来到这个界面,点击这个资源管理器,

左边会出现一个窗口,点击带+号的那个按钮

然后会在弹出一个窗口,填写数据库信息,选择的时候就会发现只能选择一个库。如果用户名和密码填写错误是连不上数据库的

连接之后何在数据库里是一样的列表。创建实体类只需要把你需要的那个表拖到空白区域就可以了。他还会显示出表之间的外键关系
建好的类就是这样,实体类在.cs里面,这里面的东西不要改,没有情况会让你改这里面的内容。
在里面找到了成员变量,这里有个partial 代表这是类的一部分,所以可以属性拓展;
接下来创建数据访问类:
创建一个类,类名与表明一致;
在类里面输入linq的名称,实例化出来;

这个东西叫做 数据库上下文;
写一个方法

这样就完成了对数据库users表的所有数据查询, 通过数据库上下文con找到users表 转换成list格式,放到ulist里面,在return出去。
更简单的也可以直接在后台里面这样写:

using是编写一个作用域,小括号后面创建一个对象,是一种很好用的对象销毁的方式。
这里创建的对象con只能在花括号里面用,走完花括号就会销毁掉。

数据拓展
属性拓展不能写在linq的.cs文件里,因为只要linq类稍微有一点变化,哪怕是表移动了一点,他就会刷新数据。

这里的类型是bool?型,还有其他?型,他和bool型区别就是一个可以为null一个不可以;
实用的时候必须吧?型装换成普通类型;
所以属性拓展要再建一个类,类名必须与表明一制。记得加上partial , 里面再写属性拓展就可以了。要return的属性通过下划线可以点出来。

如果是有外键关系的表可以直接点出来。
添加数据
准备几个textbox和一个按钮

后台 按钮的点击事件
添加数据当然还是用数据库上下文,

添加数据要用这两句,第一句con.Users.InsertOnSubmit(u) 是一个添加数据方法,括号内添加一个users类型的数据,但只是准备添加,第二句con.SubmitChanges();才是完成修改。添加数据。
删除数据
删除需要新建一个web,后台接收一下传递过来的ids。
根据这个ids查询出对应的对象,删除这个对象;
然后弹出一个提示,告诉用户删除了没。
返回页面;
这里就需要ambda表达式;
Users u = con.Users.where( r => r.ids.Tostring() == 接收的id ).FirstOrDefault();
这就是基本格式,r可以换成任意字母, =>就是基本格式 r点 就可以出现每一列的名,然后判断(转换格式);
查询出来是个集合 取值用.FirstOrDelault() 第一条或者[不存在,不执行,为空]
if(u != null)
{
con.Users.DeleteOnSubmit(u);绑定需要删除的对象
con.SubmitChanges();修改
}
修改数据
using (UsersDataClassesDataContext con = new UsersDataClassesDataContext())
{ Users u = con.Users.Where(r => r.Ids.ToString() == st).FirstOrDefault(); if (u != null)
{
if (p1.Text.Length > 0)
u.Password = p1.Text; u.Nickname = TextBox2.Text;
u.Sex = RadioButtonList1.Items[0].Selected;
u.Birthday = Convert.ToDateTime(Text_Bir.Text);
u.Nation = Dr4.SelectedValue; con.SubmitChanges(); Response.Write("<script>alert('修改成功!')</script>");
Response.Redirect("zhanshi.aspx"); } }
- con.SubmitChanges();
各修改数据准备过程就是准备修改过程,不用再用上下文对象来准备。直接一把提交
再重复一下
使用Linq时要注意:
1.创建Linq连接后生成的dbml文件不要变动,生成的表不要碰,拖动表也会造成数据库连接发生变动,需要重新保存.
2.属性拓展的使用:添加一个新的类,不要在dbml中添加属性拓展,一旦数据库变动,属性拓展类就会失效.
3.使用Linq获取的数据都是?int,?string等?数据类型,意思是也有可能为空,这时候操作数据需要先把数据类型转化成int,string等数据类型.
在这里操作数据库用到了lambda表达式,是一种匿名函数,使用lambda表达式自动带有防攻击,不需要在使用parameter了.
linq 初步认识的更多相关文章
- LINQ 初步了解
.NET Framework 3.5的新特性 Language Integrated Query,即语言集成查询 查询 和语言结合关系数据库里的信息使用的XML文档保存在本地的DataSet内存中的L ...
- LinQ的初步学习与总结
嘿嘿,说起来ORM和LinQ,就感觉离我好遥远的,在学校是没有学习的,所以总感觉学习了LinQ就是大神,现在嘛,终于也体会一点,感觉LinQ只是初步学习,没有太难,当然以后使用在项目中就没有这样的简单 ...
- LinQ实战学习笔记(一) LINQ to (Objects, XML, SQL) 入门初步
LINQ对于笔者来说, 优美而浓缩的代码让人震惊. 研究LINQ就是在艺术化自己的代码. 之前只是走马观花学会了基本的语法, 但是经常在CSDN看到令人惊讶自叹不如的LINQ代码, 还是让人羡慕嫉妒恨 ...
- Linq之Lambda表达式初步认识
目录 写在前面 匿名方法 一个例子 Lambda 定义 一个例子 总结 参考文章 写在前面 元旦三天在家闲着无事,就看了看Linq的相关内容,也准备系统的学习一下,作为学习Linq的前奏,还是先得说说 ...
- linq读书笔记1-linq 初步
至于linq是什么之类的已经有过太多的文章介绍,亦不清楚的胡朋友可以自己搜索一下便可以得到大量的答案 为了体验linq究竟能带给我们什么体验,我们直接从代码入手: string[] words = n ...
- C#学习日志 day7 --------------LINQ与Lamda语句的初步尝试以及XML的生成
LINQ是一种集成在计算机语言里的信息查询语句,是c#3.0中最惹人瞩目的功能. 在C#中,LINQ语句有两种写法. 第一种写法与SQL语句类似: IEnumerable<Customer> ...
- LINQ TO XML初步了解
最近简单的学习了一下LINT TO XML,写篇博客在这,方便以后查看~~ 1.常用到的类 XmlDocument -- 文档(xml文件) XmlElement -- ...
- [入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二)
[入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二) Date 周六 10 一月 2015 By 钟谢伟 Category website develop ...
- 小型单文件NoSQL数据库SharpFileDB初步实现
小型单文件NoSQL数据库SharpFileDB初步实现 我不是数据库方面的专家,不过还是想做一个小型的数据库,算是一种通过mission impossible进行学习锻炼的方式.我知道这是自不量力, ...
随机推荐
- jar包作用
hibernate中jar包的作用 (1)hibernate3.jar:Hibernate的核心库,没有什么可说的,必须使用的jar包 (2)cglib-asm.jar:CGLIB库,Hibernat ...
- 本地安装phpcms步骤
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u012145816/article/details/72183032 http://download ...
- uva1583(暴力枚举或打表)
紫书上的代码是打表. 我的做法是暴力枚举.注意,有多个变量时,选择枚举哪一个变量会影响到时间效率,值得考虑.由于各位数字之和最大就是五个9的和为45,所以就枚举各位数字之和比较快. #include& ...
- 转:STL迭代器失效问题
. 对于关联容器(如map, set, multimap,multiset),删除当前的iterator,仅仅会使当前的iterator失效,只要在erase时,递增当前iterator即可.这是因为 ...
- HDFS常用的Java Api详解
转自:http://blog.csdn.net/michaelwubo/article/details/50879832 一.使用Hadoop URL读取数据 package hadoop; impo ...
- Broken Keyboard(模拟数组或者双重链表的运用)
这题我是大写的服气,辛辛苦苦搞了个双重链表结果还一直不对,不对就算了,书上源代码打进去还是不对,我能怎么办我也很无奈.不过这题还是让我对双重链表更加了解和运用了!还是可以的! You’re typin ...
- C++对C语言的拓展(4)—— 函数重载
函数重载(Function Overload):用同一个函数名定义不同的函数,当函数名和不同的参数搭配时函数的含义不同. 1.重载规则 (1)函数名相同: (2)参数个数不同,参数的类型不同,参数顺序 ...
- BZOJ3403:[USACO2009OPEN]Cow Line
浅谈队列:https://www.cnblogs.com/AKMer/p/10314965.html 题目传送门:https://lydsy.com/JudgeOnline/problem.php?i ...
- mongoTemplate操作内嵌文档
关系型数据库中,表与表的关联关系有1:1,也有1:n的.在java的面向对象的世界里就是主对象嵌子对象,与主对象嵌集合<子对象>的两种形式. 主对象嵌子对象操作: 新增.修改都直接用如下方 ...
- SpringBoot之二:部署Spring Boot应用程序方式
衡量多种部署方式 Spring Boot应用程序有多种构建和运行方式,其中一些你已经使用过了. 在IDE中运行应用程序(涉及Spring ToolSuite或IntelliJ IDEA). 使用Mav ...