Entity Framework笔记(二)
前几日学习了在VS2010Console项目中使用Entity Framework,并且使用Code First模式。通过编写Model类,来生成数据库对应的表。并且,往表中写入数据以及获取表中的所有数据。这与实际应用还差很远,还没能够对数据库进行增删查改的全部操作。这一篇,记录EF中怎么进行其他的sql操作。
前一篇中,写了一个SaveUser方法。该方法向数据库中插入一条Users类的实例数据,其中使用的是userDal.user.Add()方法。将光标放到Add方法处,F12导航到该方法所在的类,可以看到这个类的内部。这是会发现,这个类里面已经有很多方法(包括之前用到的Add)。最后一行有一个SqlQuery方法,参数需要的恰巧是sql字符串和参数。

EF中的查询,支持Linq to Sql,以及sql语句的查询。有了SqlQuery这个方法,那操作数据库就没问题了,和传统的Ado.Net的方式没什么区别了,只管构造需要的sql语句好了。下面事例了带参数的查询语句:
public void FindUser()
{
UserDal userDal = new UserDal();
Console.WriteLine("Input UserName you want to find");
string userName = Console.ReadLine();
List<Users> users = userDal.users.SqlQuery("select * from T_Users where UserName like '%"+userName+"%'").ToList();
foreach (Users item in users)
{
Console.WriteLine("UserName: {0}", item.UserName);
Console.WriteLine("UserPwd: {0}", item.UserPwd);
Console.WriteLine("UserEmail: {0}", item.Email);
Console.WriteLine("UserTel: {0}", item.Tel);
Console.WriteLine("*****------**********---------********");
}
Console.ReadKey();
}
同理也可以写删除和修改操作:
public void DeleteUser()
{
UserDal userDal = new UserDal();
userDal.users.SqlQuery("delete from T_Users where UserId = {0}", );
List<Users> users = userDal.users.SqlQuery("select * from T_Users").ToList();
foreach (Users item in users)
{
Console.WriteLine("UserName: {0}", item.UserName);
Console.WriteLine("UserPwd: {0}", item.UserPwd);
Console.WriteLine("UserEmail: {0}", item.Email);
Console.WriteLine("UserTel: {0}", item.Tel);
Console.WriteLine("*****------**********---------********");
}
Console.ReadKey();
} public void UpdateUsersById()
{
UserDal userDal = new UserDal();
userDal.users.SqlQuery("update T_Users set UserName = {1} where UserId = {0}", , "yyyyxxxx");
List<Users> users = userDal.users.SqlQuery("select * from T_Users").ToList(); foreach (Users item in users)
{
Console.WriteLine("UserName: {0}", item.UserName);
Console.WriteLine("UserPwd: {0}", item.UserPwd);
Console.WriteLine("UserEmail: {0}", item.Email);
Console.WriteLine("UserTel: {0}", item.Tel);
Console.WriteLine("*****------**********---------********");
}
Console.ReadKey();
}
接下来,换一种方式。使用Linq to Sql的方式来查询数据(吐槽:跟着微软走,总会有学不完的东西。学MVC扩展出EF,学EF扩展到Linq。虽然这个东西很早之前就出了~~)。下面这个方法采用Linq to Sql 的方式查询表中UserName包含输入串的User信息。其中,第8、9、10行就是Linq的查询方式了。
public void DisplayUserByName()
{
string userName = string.Empty;
Console.WriteLine("Input UserName:");
userName = Console.ReadLine();
UserDal userDal = new UserDal();
List<Users> users = userDal.users.ToList();
var query = from b in users
where b.UserName.Contains(userName)
select b;
foreach (Users item in query)
{
Console.WriteLine("UserName: {0}", item.UserName);
Console.WriteLine("UserPwd: {0}", item.UserPwd);
Console.WriteLine("UserEmail: {0}", item.Email);
Console.WriteLine("UserTel: {0}", item.Tel);
}
}
到此,已经可以使用EF对数据库进行常见的操作了。但是DbSet类下面的那么多方法,还是需要去继续研究。同时,EF不仅仅只有Code First模式(该模式还存在问题,当模型更改后,会将原来的数据库删除,重新建立新的数据库。这在开发过程中是不想碰到的,因为会将前期输入的大量测试数据一同删除)。EF还可以连接到已经存在的数据,将已有的数据库表映射成模型类。(这才是EF作为ORM框架的本质)
待续~~~
Entity Framework笔记(二)的更多相关文章
- Entity Framework笔记(一)
最近在看MVC方面的资料,看了几个教程都在使用Entity Framework做数据持久化.之前也听说过这个东西,在微软的网站上看过一个演示视频,但都没怎么去仔细研究.MVC的东西太庞大了,先慢慢熟悉 ...
- Entity Framework 笔记(一)
Entity Framework概述 EF是一个对象关系映射(ORM)框架,允许开发人员使用特定于域的对象关系型数据,开发人员通常不需要编写大量的数据访问代码.使用EF,开发者可以利用LINQ进行查询 ...
- Entity Framework(二)
1. ORM :Object Relation Mapping ,通俗说:用操作对象的方式来操作数据库. 2. 插入数据不再是执行Insert,而是类似于 Person p=new Person() ...
- .NET:Entity Framework 笔记
有二年没关注EF,今天无意试了下发现跟主流的Hibernate等ORM框架越来越接近了,先看下Entity类的定义: using System; using System.Collections.Ge ...
- robot framework笔记(二):在RF中自定义chrome启动参数
(一)在RF中自定义chrome启动参数 这里主要是实现下面2个功能 1.禁用chrome正受自动测试软件控制的提示 2.设置默认的下载路径(一些导出.下载类的功能,将文件下载到指定路径下) 自定义一 ...
- Entity Framework 程序设计入门二 对数据进行CRUD操作和查询
前一篇文章介绍了应用LLBL Gen生成Entity Framework所需要的类型定义,用一行代码完成数据资料的读取, <LLBL Gen + Entity Framework 程序设计入门& ...
- Entity FrameWork 操作使用详情
Entity FrameWork 是以ADO.net为基础发展的ORM解决方案. 一.安装Entity FrameWork框架 二.添加ADO.Net实体数据模型 三.EF插入数据 using Sys ...
- Entity Framework学习笔记(二)----CRUD(1)
请注明转载地址:http://www.cnblogs.com/arhat 这篇文章老魏和大家分享一下Entity Framework的CRUD操作,在这之前呢,老魏先说一下老魏对EF的一个整体的认识, ...
- Entity Framework 学习笔记(二)之数据模型 Model 使用过程
Entity Framework 数据模型 Model 创建的使用: 开发环境:VS2012 数据库:SQL Server 2008 Entity Framework 版本:6.12 下面是新建的 ...
随机推荐
- Android SDK 5.0 这个语句带来折腾 - 生命在于折腾!
Android SDK 5.0 带来的这番折腾 - 生命在于折腾! 太阳火神的漂亮人生 (http://blog.csdn.net/opengl_es) 本文遵循"署名-非商业用途-保持一 ...
- OSGI学习总结
最近的一项研究了解了一下OSGI技术,感觉OSGI尽管有一定的学习难度.可是终于掌握和推广之后将是一项对系统开发比較实用的技术.在此和大家分享一下自己的感悟. 1.什么是OSGI OSGI直译为&qu ...
- spring问题排查-调低日志等级
问题描写叙述 1. 页面经过一次改动后,提交后页面出现400错误,可是后台并没有输出不论什么错误信息. 2. debug监听应页面对应的提交链接也没有不论什么反应(没有进入后台的controller方 ...
- 远程连接到vultr vps的mysql服务器
实验环境 vultr centos 6.7 x64 1. 首先要打开远程 vps的3306端口用于 mysql的连接 修改/etc/sysconfig/iptables 文件,添加3306端口的支持 ...
- springmvc如何访问静态文件,例如jpg,js,css
你怎么DispatcherServlet拦截"*.do"这有一个后缀URL.就不存在訪问不到静态资源的问题. 假设你的DispatcherServlet拦截"/&qu ...
- 小米2S twrp 中文,支持双系统
更新日志: 更新日志: 汉化了要使用的功能 修改语言选择方式,修改为下拉方式 TDB(TrueDualBoot) 功能完美实现 **adb**功能,完美实现,无需特别操作(比CWM强大) 修改双系统切 ...
- Nubia Z5S 官方4.4 201内測版 内核版本号信息
从egl推断内核的的版本号: OpenGL ES Shader Compiler Version: E031.24.00.14 Build Date: 04/29/14 Tue Local Branc ...
- mapreduce程序来实现分类
文件的内容例如以下所看到的: 5 45 8 876 6 45 要求最后的输出格式: 1 5 2 6 3 8 4 45 5 45 5 876 首先,这个题目是须要对文 ...
- 采用Eclipse中间Maven构建Web项目错误(一)
采用Eclipse中间Maven构建Web工程 1.在进行上述操作时.pom.xml一直报错 <project xmlns="http://maven.apache.org/POM/4 ...
- Android的第二次增加SurfaceView基本使用
本文来源于http://blog.csdn.net/hellogv/ ,引用必须注明出处. 上次介绍MediaPlayer的时候略微介绍了SurfaceView,SurfaceView因为能够直接从内 ...