zoukankan      html  css  js  c++  java
  • EF6中执行Sql语句

    EF中提供了两个方法,一个是执行查询的Sql语句SqlQuery,另外一个是执行非查询的语句ExecuteSqlCommand。SqlQuery有两种形式的,一种是泛型的,一种是非泛型的。比如我们要在目录表中查询ID为多少的一个分类。可以这样写:

    entityList = dbContext.Set<Catalog>().SqlQuery("Select * from catalog where CatalogID='1234'").ToList();

           它会为你自动转换成对应的实体的。另外,如果你想查询目录表中所有的记录数,那么你可以这样写:

    int countNum = dbContext.Database.SqlQuery<int>("Select count(*) from catalog").ToList()[0];

            如果你想执行一些非查询的Sql语句,你可以调用ExecuteSqlCommand方法,它会返回受影响的行数。你可以这样写:

    int num = dbContext.Database.ExecuteSqlCommand("delete from catalog where CatalogID='212222' ");

            返回值是执行这个非查询语句后,受影响的行数。如果你在ExecuteSqlCommand方法中传入了一个查询类的Sql语句,不管查询出来的结果是什么,它返回的都是-1。如:

    int num = dbContext.Database.ExecuteSqlCommand("Select count(*) from catalog");//结果是-1

    转自:https://www.cnblogs.com/xiaoxiangfeizi/p/3551855.html,表示感谢。
  • 相关阅读:
    Java IO包装流如何关闭?
    Validator关于js,jq赋值不触发验证解决办法
    4 统计量&抽样分布
    3 概率的基本概念&离散型随机变量
    2 数据的概括性度量
    1 数据 & 图表
    Python 闭包
    一个自动修正数据时间和补全缺失数据的MapReduce程序
    MapReduce原理
    Hadoop MapReduce常用输入输出格式
  • 原文地址:https://www.cnblogs.com/SimpleGIS/p/9315647.html
Copyright © 2011-2022 走看看