Linq to SQL 小结
前天开始看这方面的资料,虽然看了网上对比 sql和linq的速度,万条数据可能要慢1/4左右的数度,但是介于的方便,还是学了
首先看看linq的基本语法:
FROM XX IN DATASOURCE
WHERE 条件表达式
ORDERBY XXXXX
SELECT XX
和T-sql语句很像,只是说顺序有点不一样罢了
我的是VS2012的环境,在项目中添加Linq to sql 的类,后缀是dbml,然后把你的数据库中的表直接拖到界面上就是,对,就是直接拖就可以了,这样好像所谓的ORM(对象关系映射)层就弄好了
这样之后我们就可以通过linq to sql 很简单的去操作数据库了
vs会自动生成一个datacontext的类(又成为上下文类),(根据dbml文件的名字生成的)我这边是linq_notedatacontext
首先我们先来做查询:
linq_noteDataContext l = new linq_noteDataContext();
实例化datacontext
linq_noteDataContext l = new linq_noteDataContext ();
var results = from data in l.note
where data.title = "我的祖国"
select data;
foreach (var d in results)
Response.Write(d.ToString());
插入操作
//插入数据库 db_product_information pdd = new db_product_information(); //实例化你数据库中的一张表,额。。。应该称之为实例化吧
pdd.Product_id = "";
pdd.Product_name = "hrx";
pdd.Product_sum = ;
pdd.support_id = ;
productDataContext pd = new productDataContext(); //datacontext
pd.db_product_information.InsertOnSubmit(pdd); //插入操作
pd.SubmitChanges();//更新到数据库,这个动作,不管是插入删除,还是更新都要
修改操作
//修改数据
productDataContext pd = new productDataContext();
var result = from data in pd.db_product_information
where data.support_id ==
select data;
foreach (var i in result)
{
i.support_id = ;
}
pd.SubmitChanges();
删除操作
//删除数据
productDataContext pd = new productDataContext();
var result = from data in pd.db_product_information
where data.Product_name == "hrx"
select data;
foreach (var i in result)
{
pd.db_product_information.DeleteOnSubmit(i);
pd.SubmitChanges();
}
然后是使用存储过程
同样,我们把存储过程直接拖到dbml设计器上
vs会自动在datacontext派生类里面生成相关的存储过程的调用方法:
我们依然就是直接用就可以了
//使用存储过程
productDataContext pd = new productDataContext();
var result = from data in pd.sp_product() //sp_product是我的存储过程的名字
select data;
foreach (var i in result)
{
listBox1.Items.Add(i.Product_id .ToString()+" "+i.Product_name .ToString ()+" "+i.Product_sum .ToString ()+" "+i.support_id .ToString ());
}
这些操作我想做中小项目应该是够了吧?
还有延迟加载什么的我看不懂。。
Linq to SQL 小结的更多相关文章
- LINQ to SQL语句(7)之Exists/In/Any/All/Contains
适用场景:用于判断集合中元素,进一步缩小范围. Any 说明:用于判断集合中是否有元素满足某一条件:不延迟.(若条件为空,则集合只要不为空就返回True,否则为False).有2种形式,分别为简单形式 ...
- 年终巨献 史上最全 ——LINQ to SQL语句
LINQ to SQL语句(1)之Where 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句.Where操 ...
- LINQ to SQL语句(20)之存储过程
在我们编写程序中,往往需要一些存储过程,在LINQ to SQL中怎么使用呢?也许比原来的更简单些.下面我们以NORTHWND.MDF数据库中自带的几个存储过程来理解一下. 1.标量返回 在数据库中, ...
- LINQ to SQL语句(19)之ADO.NET与LINQ to SQL
它基于由 ADO.NET 提供程序模型提供的服务.因此,我们可以将 LINQ to SQL 代码与现有的 ADO.Net 应用程序混合在一起,将当前 ADO.NET 解决方案迁移到 LINQ to S ...
- LINQ to SQL语句(18)之运算符转换
运算符转换 1.AsEnumerable:将类型转换为泛型 IEnumerable 使用 AsEnumerable<TSource> 可返回类型化为泛型 IEnumerable 的参数.在 ...
- LINQ to SQL语句(17)之对象加载
对象加载 延迟加载 在查询某对象时,实际上你只查询该对象.不会同时自动获取这个对象.这就是延迟加载. 例如,您可能需要查看客户数据和订单数据.你最初不一定需要检索与每个客户有关的所有订单数据.其优点是 ...
- LINQ to SQL语句(14)之Null语义和DateTime
Null语义 说明:下面第一个例子说明查询ReportsToEmployee为null的雇员.第二个例子使用Nullable<T>.HasValue查询雇员,其结果与第一个例子相同.在第三 ...
- LINQ to SQL语句(10)之Insert
1.简单形式 说明:new一个对象,使用InsertOnSubmit方法将其加入到对应的集合中,使用SubmitChanges()提交到数据库. var newCustomer = new Custo ...
- Linq to SQL 语法查询(链接查询,子查询 & in操作 & join,分组统计等)
Linq to SQL 语法查询(链接查询,子查询 & in操作 & join,分组统计等) 子查询 描述:查询订单数超过5的顾客信息 查询句法: var 子查询 = from c i ...
随机推荐
- Django+Celery+Redis实现异步任务(发送邮件)
安装如下依赖库 pip install Celery pip install django-celery pip install django-redis 还要安装本地的Redis服务 setting ...
- (转) Parameter estimation for text analysis 暨LDA学习小结
Reading Note : Parameter estimation for text analysis 暨LDA学习小结 原文:http://www.xperseverance.net/blogs ...
- [SCOI2007]组队 差分
题面:[SCOI2007]组队 题解: 一开始固定H然后找性质找了很久也没有找到任何有用的东西...... 然后大佬告诉我一个神奇的方法... 首先我们化一波式子: 设$H$表示高度的最小值,$V$表 ...
- [NOI2001]炮兵阵地 状压DP
题面: 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用“H” 表示),也可能是平原(用“P”表示),如下图.在每一格平原地形上最多 ...
- 【基础】ASP.net MVC 文件下载的几种方法(欢迎讨论)
在ASP.net MVC 中有几种下载文件的方法 前提:要下载的文件必须是在服务器目录中的,至于不在web项目server目录中的文件下载我不知道,但是还挺想了解的. 第一种:最简单的超链接方法,&l ...
- BZOJ5324 & 洛谷4563 & LOJ2545:[JXOI2018]守卫——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=5324 https://www.luogu.org/problemnew/show/P4563 ht ...
- BZOJ1009:[HNOI2008]GT考试——题解
http://www.lydsy.com/JudgeOnline/problem.php?id=1009 Description 阿申准备报名参加GT考试,准考证号为N位数X1X2....Xn(0&l ...
- github clone 指定的tag
git clone --branch [tags标签] [git地址] 使用branch参数,后面加上tag标签,最后是git仓库的地址
- Linux系统通过AWS命令行上传文件至S3
打开你的AWS控制台: 在IAM中创建一个新用户(比如test),创建时它会自动创建一个用户安全凭证,是由“访问密钥ID”和“私有访问密钥”组成的,请记住它并下载该凭证,后面会用到它: 选择你刚创建的 ...
- UVA10600:ACM Contest and Blackout(次小生成树)
ACM Contest and Blackout 题目链接:https://vjudge.net/problem/UVA-10600 Description: In order to prepare ...