博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linq 增删改查
阅读量:6413 次
发布时间:2019-06-23

本文共 2307 字,大约阅读时间需要 7 分钟。

数据库访问技术:

  ADO.net

  EF框架

  LinQ

LinQ是一种高集成化的数据库访问技术,他将数据库中的表映射成程序中的类

  数据库的表名变成类名

  数据库的列名变成字段名/属性名

所有的操作都是通过LinQ自动生成的一个上下文对象来进行操作的,这个对象名是LinQ的名字+"DataContext" ,一个数据库对应一个LinQ

 

去除数据访问类的简便开发方式

  使用LinQ时,可以不写数据访问类,直接在程序用调用,这样既省时间,也节省内存

  使用方法:using(实例化上下文对象){}

 

using (Data0928DataContext con = new Data0928DataContext())            {                Repeater1.DataSource = con.Users.ToList();                Repeater1.DataBind();            }

查询、条件查询

  普通查询:查询全部只需一句代码

 

con.Users.Tolist();

 

  条件查询:需要使用Lambda表达式

  注意:不管结果有几条数据,返回的都是集合,使用FirstOrDefault取第一个值,并且如果为空不会报错,会返回null

Users u = con.Users.Where(r => r.ids == ids1).FirstOrDefault();

删除

  删除方法需要一个对象,需要先通过条件查询查出此对象才能进行删除,并且需要SubmitChanges方法才是正式执行方法

 

con.Users.DeleteOnSubmit(con.Users.Where(r => r.ids == ids1).FirstOrDefault());con.SubmitChanges();

 

修改

  修改不需要想ADO.net中那样需要写很长的字符串,只需要查出需要修改的对象,对这个对象的属性直接修改,修改完毕执行SubmitChanges方法提交即可

 

Users u = con.Users.Where(r => r.UserName == username.Text).FirstOrDefault();                u.PassWord = password.Text;                u.NickName = nickname.Text;                if (RadioButton1.Checked)                    u.Sex = true;                else                    u.Sex = false;                u.Birthday = Convert.ToDateTime(birthday.Text);                u.Nation = DropDownList1.SelectedValue;                u.Class = DropDownList2.SelectedValue;                try                {                    con.SubmitChanges();                    Response.Redirect("Index.aspx");                }                catch {                    Label1.Text = "修改失败!";                }

 

属性扩展

  VS允许用户对LinQ生成的实体类进行扩展,只需要创建一个跟实体类相同名的类,写上partial,即可在此类里面写自己需要的属性。

  直接在LinQ生成的文件中写也有效,但是如果对LinQ执行任何修改,哪怕只是拖动一下界面的表位置,也会导致代码重新生成,这样自己写进去的属性扩展就会消失,所以只能通过新建一个同名partial类进行添加

 

public partial class Users{    public string SexStr    {        get        {            string end = "空";            if (this._Sex != null)            {                end = Convert.ToBoolean(this._Sex) ? "images/man.png" : "images/woman.png";            }            return end;        }    }    public string NationName    {        get        {            return Nation1.NationName;        }    }    public string ClassName    {        get        {            return Class1.ClassName;        }    }}

转载于:https://www.cnblogs.com/maxin991025-/p/6379863.html

你可能感兴趣的文章
java发送邮件 不登陆_Java邮件到Exchange Server“不支持登录方法”
查看>>
编程学习初体验(5. 如何自学编程)(2)
查看>>
思科ISR G1与ISR G1C的区别
查看>>
利用perl提取web配置文件中的域名对应的路径
查看>>
Centos5上安装JRE和LUMAQQ
查看>>
关于监控工具的主动发起性能测试
查看>>
我的友情链接
查看>>
OpenSSL学习(十六):基础-指令rand
查看>>
KeyMob致力于打造国内领先的移动广告平台
查看>>
路由选路原则
查看>>
jvm 学习(一)
查看>>
JavaScript简介
查看>>
SQL Server附加数据库拒绝访问解决方法汇总
查看>>
SM2算法原理及实现
查看>>
RHCA教材翻译计划
查看>>
js-小括号在不同场合下的作用
查看>>
我的友情链接
查看>>
kvm中虚拟机的硬盘扩容
查看>>
Android (Launch Mode) 四种启动模式
查看>>
透视学理论(二)
查看>>