引言

从EF6开始,增加了DateBase类,他通过从 DbContext 对象获取此类的实例。可用于管理支持数据库上下文或连接的实际数据库。这包括创建、删除和检查数据库的存在。

在6以前,我们使用EF,需要借助ADO.NET才能直接执行SQL语句。由于Linq查询自身存在的一些短板,例如有以下场景:在上万的数据容量的情况下,需要联合3个表以下的查询统计时,Linq就显出了自己的不足。这时 有一定经验的人肯定想到了使用存储过程 将业务中复杂的逻辑运算放到数据库执行,这时就需要用到DataBase

下面我就DataBase类提供的一些常用方法,帮助我们在程序中直接对数据库进行读写操作。

正文

1. SqlQuery<T>(string sql,params object[] parameter)

使用SqlQuery<T>()执行Sql语句,存储过程,视图

仓储层代码

        public IQueryable<TEntity> QuerySql<TEntity>(string strSql, params SqlParameter[] dbParameter) where TEntity : class
{
return dbcontext.Database.SqlQuery<TEntity>(strSql, dbParameter).AsQueryable<TEntity>();
}

dbcontext: EF上下文

执行sql语句

var data = new RepositoryBase().QuerySql<CustomerListViewModel>(sqlStr);

CustomerListViewModel:查询结果的DTO对象,通过这种方式,只要你的DTO的属性与查询结果的返回字段一致,就可以将查询结果映射到DTO

执行存储过程

        public List<StoreListViewModel> QueryStoreListSplit(Pagination pagination, string uId, string shopCode)
{
List<StoreListViewModel> dtoResult = new List<StoreListViewModel>();
string sqlwhere = "";
string msg = "";
string sqlStr = "EXEC [dbo].[sp_CustomerStoreList] @UId, @Where, @msg OUT";
if (!string.IsNullOrEmpty(shopCode))
{
sqlwhere = " AND s.F_ShopCode = '" + shopCode + "'";
} SqlParameter[] parms = new SqlParameter[]
{
new SqlParameter("@UId",uId),
new SqlParameter("@Where",sqlwhere),
new SqlParameter("@msg",System.Data.SqlDbType.NVarChar,200)
};
parms[2].Direction = System.Data.ParameterDirection.Output; dtoResult = customerRepository.GetCustomerStoreList(sqlStr, pagination, parms);
msg = parms[2].Value.ToString(); return dtoResult;
}

2. 使用 ExecuteSqlCommand()实现 创建,更新,删除

using (var db = new DBModel()) //创建数据库上下文
{
//同步的方式执行SQL,并返回受影响的行数
int result = db.Database.ExecuteSqlCommand(@"CREATE TABLE `test` (
`id` INT NOT NULL,
PRIMARY KEY(`id`)); "); //使用SqlParameter传值可以避免SQL注入
var p_name = new SqlParameter("@name", "萝莉");
var p_age = new SqlParameter("@age", 13); //如果使用的是MySql数据库 需要SqlParameter把替换为MySqlParameter
//var p_name = new MySqlParameter("@name", "萝莉");
//var p_age = new MySqlParameter("@age", 13);
//更改学生年龄
result = db.Database.ExecuteSqlCommand(@"UPDATE `student`
SET `age` = @age
WHERE `name` = @name;", p_age, p_name); //异步的方式执行SQL,并返回受影响的行数
Task<int> result2 = db.Database.ExecuteSqlCommandAsync("DROP TABLE `test`;");
}

注:如果需要创建或删除当前数据库,Database属性中还存在.Create() 和.Delete()方法,它们不接受参数,返回一个bool值表示执行成功或失败。

3. 使用DbSet<T>下的.SqlQuery()

在每个数据实体集合DbSet<T>下也有一个.SqlQuery(),功能与上面介绍的一样,只不过DbSet<T>下的.SqlQuery()只能返回DbSet<T>中包含的类型。但DbSet<T>下的.SqlQuery()在返回数据的同时还会让数据库上下文(DBModel)跟踪返回数据的状态,如果返回的数据发生了修改,就可以使用.SaveChanges()将结果直接保存回数据库。而.Database.SqlQuery()查出的结果则是做不到的。

using (var db = new DBModel()) //创建数据库上下文
{
//查询叫萝莉的学生信息,并修改她的年龄
student result1 = db.students.SqlQuery("SELECT * FROM student WHERE name = '萝莉'").FirstOrDefault();
result1.age = 13; //通过实体集合下.SqlQuery查询到的数据,修改之后是可以保存到数据库的 student result2 = db.Database.SqlQuery<student>("SELECT * FROM student WHERE name = '旺财'").FirstOrDefault();
result2.age = 21; //因为使用的是.Database.SqlQuery查询到的,所以这里的修改不会保存到数据库 //如果希望.Database.SqlQuery下查出的数据在修改后也能保存到数据库
student result3 = db.Database.SqlQuery<student>("SELECT * FROM student WHERE name = '小明'").FirstOrDefault();
result3.age = 36;
db.Entry<student>(result3).State = System.Data.Entity.EntityState.Modified;//通知数据上下文,这条记录也被修改了
db.SaveChanges();
}

4.BeginTransaction()

对基础存储连接开始一个事务

            //事务处理
using (DbContextTransaction dbTransaction = deliverRepository.EFDb.Database.BeginTransaction())
{
try
{
//需要事务处理的逻辑代码 //事务提交
dbTransaction.Commit(); }
catch (Exception ex)
{
dbTransaction.Rollback();
throw new Exception(ex.Message);
} }

DataBase类的基本用法就这么多,有什么遗漏的欢迎大家补充!

PS:欢迎扫描下方二维码,加入QQ群

 
作者:Jacky
声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

Asp.Net MVC EF之一:使用Database类在EF框架中执行Sql语句的更多相关文章

  1. easyui datagrid 禁止选中行 EF的增删改查(转载) C# 获取用户IP地址(转载) MVC EF 执行SQL语句(转载) 在EF中执行SQL语句(转载) EF中使用SQL语句或存储过程 .net MVC使用Session验证用户登录 PowerDesigner 参照完整性约束(转载)

    easyui datagrid 禁止选中行   没有找到可以直接禁止的属性,但是找到两个间接禁止的方式. 方式一: //onClickRow: function (rowIndex, rowData) ...

  2. 在EF中执行SQL语句(转载)

    在EF中执行SQL语句   你可能要问,我用EF不就为了避免写SQL吗?如果要写SQL我不如直接用ADO.NET得了.话虽然这么说没错,可有些时候使用EF操作数据还是有一些不方便,例如让你根据条件删除 ...

  3. EF中执行sql语句,以及事务

    EF to sql string sql = "select T_Task.BSID,T_Task.CloseDate,T_Task.CompleteDate,T_Task.CloseUse ...

  4. 在EF中执行SQL语句

    你可能要问,我用EF不就为了避免写SQL吗?如果要写SQL我不如直接用ADO.NET得了.话虽然这么说没错,可有些时候使用EF操作数据还是有一些不方便,例如让你根据条件删除一组记录,如果按照正常的流程 ...

  5. EF中执行Sql语句

    Entity Framework是微软出品的高级ORM框架,大多数.NET开发者对这个ORM框架应该不会陌生.本文主要罗列在.NET(ASP.NET/WINFORM)应用程序开发中使用Entity F ...

  6. EF5中 执行 sql语句使用Database.ExecuteSqlCommand 返回影响的行数 ; EF5执行sql查询语句 Database.SqlQuery 带返回值

    一: 执行sql语句,返回受影响的行数 在mysql里面,如果没有影响,那么返回行数为  -1 ,sqlserver 里面  还没有测试过 using (var ctx = new MyDbConte ...

  7. EF Core中执行Sql语句查询操作之FromSql,ExecuteSqlCommand,SqlQuery

    一.目前EF Core的版本为V2.1 相比较EF Core v1.0 目前已经增加了不少功能. EF Core除了常用的增删改模型操作,Sql语句在不少项目中是不能避免的. 在EF Core中上下文 ...

  8. EF Core 执行SQL语句和存储过程

    无论ORM有多么强大,总会出现一些特殊的情况,它无法满足我们的要求.在这篇文章中,我们介绍几种执行SQL的方法. 表结构 在具体内容开始之前,我们先简单说明一下要使用的表结构. public clas ...

  9. MVC EF 执行SQL语句(转载)

    MVC EF 执行SQL语句 最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来. 十年河东十年河西,莫欺少年穷 学无止境,精益求精 闲着没事,看了一篇关于LI ...

随机推荐

  1. repeater嵌套RadioButtonList赋值

    <asp:Repeater ID="Repeater1" runat="server"         onitemdatabound="Rep ...

  2. [leetcode]403. Frog Jump青蛙过河

    A frog is crossing a river. The river is divided into x units and at each unit there may or may not ...

  3. cookie的基本用法

    1.创建cookie对象 Cookie newCookie=new Cookie(String ky,String value); 2.写入cookie response.addCookie(newC ...

  4. jdk8 jvm配置参数说明

    这些选项是特定于Java HotSpot虚拟机的通用选项.-X 显示所有可用-X选项的帮助. -Xbatch 禁用后台编译.默认情况下,JVM将该方法编译为后台任务,以解释器模式运行该方法,直到后台编 ...

  5. IDEA 的VM Option设置加快页面的加载速度

    VM Option的设置: -Xms1024M -Xmx2048M -XX:PermSize=128M -XX:MaxPermSize=256M

  6. div+css隐藏内容样式方法

    div css隐藏内容样式方法     div+css隐藏内容方法 一般情况下,css隐藏的用途,如下: 1.对文本的隐藏 2.隐藏超链接(另类黑链) 3.对统计代码隐藏 4.隐藏超出图片 5.css ...

  7. Mysql的内存优化

     老师  vi mysqld_safe# executing mysqld_safe 后面增加export LD_PRELOAD=/usr/local/lib/libtcmalloc.so  可以做一 ...

  8. vue cli+axios踩坑记录+拦截器使用,代理跨域proxy(更新)

    16319 1.首先axios不支持vue.use()方式声明使用,看了所有近乎相同的axios文档都没有提到这一点建议方式 在main.js中如下声明使用 import axios from 'ax ...

  9. Java 8 Stream API

    Java 8 Stream API JDK8 中有两大最为重要的改变.第一个是 Lambda 式:另外 Stream API(java.util.stream.*) Stream 是 JDK8 中处理 ...

  10. 测试这个才可以打包 我的PYQt matplotlib numpy 等程序

    from distutils.core import setup import py2exe import matplotlib import sys import FileDialog import ...