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 ...
随机推荐
- vscode Variables Reference
vscode Variables Reference 您可以在以下链接中找到该列表:https://code.visualstudio.com/docs/editor/variables-refere ...
- AOJ.859 地毯填补问题 (递归与分治)
AOJ.859 地毯填补问题 (递归与分治) 题意分析 学习分治思想,第一次接触, 代码总览 #include <iostream> #include <cstdio> #in ...
- lnmp架构 实现lbs资料参考
查找附近的xxx 球面距离以及Geohash方案探讨 http://www.wubiao.info/372 http://digdeeply.org/archives/06152067.html
- libudev使用说明书
转http://blog.csdn.net/coroutines/article/details/38067805 1. 初始化 首先调用udev_new,创建一个udev library conte ...
- Hadoop,大数据,云计算三者之间的关系
大数据和云计算是何关系?关于大数据和云计算的关系人们通常会有误解.而且也会把它们混起来说,分别做一句话直白解释就是:云计算就是硬件资源的虚拟化;大数据就是海量数据的高效处理.大数据.hadoop及云计 ...
- bzoj [POI2005]Kos-Dicing 二分+网络流
[POI2005]Kos-Dicing Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1835 Solved: 661[Submit][Status][ ...
- 可能是国内最火的开源项目 —— C/C++ 篇
程序员们,在北上广你还能买房吗? >>> 推荐阅读: 可能是最火的开源项目 -- Java 篇 可能是国内最火的开源项目 -- PHP 篇 可能是国内最火的开源项目 -- Pyt ...
- 51Nod 1031 骨牌覆盖 | Fibonacci
Input 输入N(N <= 1000) Output 输出数量 Mod 10^9 + 7 Input示例 3 Output示例 3 思路:对于第x块骨牌的情况,我们用a[x]表示其方法数:其比 ...
- HDU 5942 Just a Math Problem 容斥 莫比乌斯反演
题意:\( g(k) = 2^{f(k)} \) ,求\( \sum_{i = 1}^{n} g(i) \),其中\( f(k)\)代表k的素因子个数. 思路:题目意思很简单,但是着重于推导和简化,这 ...
- 如何生成Java Key以及sign一个jar
1. 生成Java Key: keytool -genkey -alias mydomain -keyalg RSA -keystore keystore.jks -keysize mydomain ...