您当前的位置: 首页 > 

寒冰屋

暂无认证

  • 0浏览

    0关注

    2286博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

使用实体框架返回数据表

寒冰屋 发布时间:2020-04-23 21:24:29 ,浏览量:0

目录

背景

扩展方式

实体框架(Entity Framework)

实体框架核心(Entity Framework Core)

使用扩展方法

使用常规查询

使用参数化查询

不同数据库的DbParameter名称

将源代码与SQL-Server Db一起使用

Db对象

解决方案和项目

  • 下载源8.9 KB
背景

在应用程序的特定情况下,我们必须以DataTable对象的形式获取结果。该应用程序正在使用Oracle数据库和Entity Framework EDMX。我们必须使用现有的数据库上下文实例从未映射的共享视图中选择数据。为此,我实际上为DbContext对象编写了一些扩展方法,如下所述。

扩展方式

我们将创建DbContext同时考虑Entity Framework和Entity Framework Core的扩展方法。扩展方法将通过以下方式调用:

  • SQL查询字符串
  • 可选DbParameter对象,如果使用参数化查询

让我们开始编写代码。

实体框架(Entity Framework)
using System.Data;
using System.Data.Common;
using System.Data.Entity;

public static class DbContextExtensions
{
    /*
     * need
        Only EntityFramework
     */
    public static DataTable DataTable(this DbContext context, string sqlQuery, 
                                      params DbParameter[] parameters)
    {
        DataTable dataTable = new DataTable();
        DbConnection connection = context.Database.Connection;
        DbProviderFactory dbFactory = DbProviderFactories.GetFactory(connection);
        using (var cmd = dbFactory.CreateCommand())
        {
            cmd.Connection = connection;
            cmd.CommandType = CommandType.Text;
            cmd.CommandText = sqlQuery;
            if (parameters != null)
            {
                foreach (var item in parameters)
                {
                    cmd.Parameters.Add(item);
                }
            }
            using (DbDataAdapter adapter = dbFactory.CreateDataAdapter())
            {
                adapter.SelectCommand = cmd;
                adapter.Fill(dataTable);
            }
        }
        return dataTable;
    }
}
实体框架核心(Entity Framework Core)
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data;
using System.Data.Common;
using Microsoft.EntityFrameworkCore;

public static class DbContextExtensions
{
    /*
     * need
        Microsoft.EntityFrameworkCore
        Microsoft.EntityFrameworkCore.Relational
     */
    public static DataTable DataTable(this DbContext context, 
           string sqlQuery, params DbParameter[] parameters)
    {
        DataTable dataTable = new DataTable();
        DbConnection connection = context.Database.GetDbConnection();
        DbProviderFactory dbFactory = DbProviderFactories.GetFactory(connection);
        using (var cmd = dbFactory.CreateCommand())
        {
            cmd.Connection = connection;
            cmd.CommandType = CommandType.Text;
            cmd.CommandText = sqlQuery;
            if (parameters != null)
            {
                foreach (var item in parameters)
                {
                    cmd.Parameters.Add(item);
                }
            }
            using (DbDataAdapter adapter = dbFactory.CreateDataAdapter())
            {
                adapter.SelectCommand = cmd;
                adapter.Fill(dataTable);
            }
        }
        return dataTable;
    }
}

我试图将代码放到一个普通项目中,这实际上取决于Microsoft.EntityFrameworkCore.Relational。默认情况下,它会自动包含任何提供程序DLL,比如Microsoft.EntityFrameworkCore.SqlServer。

使用扩展方法 使用常规查询
var db = new MopDb();
DataTable allUser = db.DataTable("SELECT * FROM [dbo].[tbl_test_role]");
使用参数化查询
var db = new MopDb();

/*stored procedure*/
DataTable searchUser = db.DataTable(
    "EXEC sp_test_role @name = @paramName",
    new SqlParameter("paramName", SqlDbType.NVarChar) { Value = "sa" }
);

/*select query*/
DataTable likeUser = db.DataTable(
    "SELECT * FROM [dbo].[tbl_test_role] WHERE [name] LIKE '%' + @paramName +'%'",
    new SqlParameter("paramName", SqlDbType.NVarChar) { Value = "a" }
);

我们正在执行存储过程和查询,我相信函数也将起作用。

不同数据库的DbParameter名称
  • SqlServer:SqlParameter
  • Oracle:OracleParameter
  • MySql的:MySqlParameter
  • PostgreSQL的:NpgsqlParameter
将源代码与SQL-Server Db一起使用 Db对象

创建Db对象

CREATE TABLE [dbo].[tbl_test_role] (
    [id]   INT           IDENTITY (1, 1) NOT NULL,
    [name] NVARCHAR (50) NOT NULL,
    [details] NVARCHAR (150) NULL,
    PRIMARY KEY CLUSTERED ([id] ASC)
);
INSERT INTO [dbo].[tbl_test_role] (name)
VALUES ('admin'), ('sa'), ('user');


CREATE PROCEDURE sp_test_role @name nvarchar(30)
AS
BEGIN
    SELECT * FROM [dbo].[tbl_test_role]
    WHERE [name] = @name;
END;

如果需要,可以删除Db对象

DROP TABLE [dbo].[tbl_test_role];
DROP PROCEDURE sp_test_role;
解决方案和项目

这是Visual Studio 2017解决方案:

  • WithEf 是.NET Framework 4.5
  • WithEfCore 是.NET Core 2.2

更改连接字符串

WithEf中的App.config:


  

WithEfCore中的appsettings.json:

"ConnectionStrings": {
  "MopDbConnection": "server=10.10.15.13\\DB002;database=TESTDB;
                      user id=FSTEST;password=dhaka"
}

 

关注
打赏
1665926880
查看更多评论
立即登录/注册

微信扫码登录

0.0459s