zoukankan      html  css  js  c++  java
  • EF core 学习 执行原生sql语句 之ExecuteReader 和ExecuteScalar

    通过ef core 源码分析 Microsoft.EntityFrameworkCore.Storage.RelationalCommandExtensions类中有相应的方法 为此得到相应的结果:

    为此在我们的数据上下文中拓展方法:

     public async Task<DbDataReader> ExecuteReaderAsync(RawSqlString sql, params object[] parameters)
            {
                using (await Database.GetService<IConcurrencyDetector>().EnterCriticalSectionAsync(default))
                {
                    RawSqlCommand rawSqlCommand = Database.GetService<IRawSqlCommandBuilder>().Build(sql.Format, parameters);
                    return (await rawSqlCommand.RelationalCommand.ExecuteReaderAsync(Database.GetService<IRelationalConnection>(), rawSqlCommand.ParameterValues)).DbDataReader;
                }
            }
            //  FormattableString
            public Task<DbDataReader> ExecuteReaderAsync(FormattableString sql)
            {
                return ExecuteReaderAsync(sql.Format, sql.GetArguments());
            }
            public Task<object> ExecuteScalarAsync(FormattableString sql)
            {
                return ExecuteScalarAsync(sql.Format, sql.GetArguments());
            }
            public async Task<object> ExecuteScalarAsync(RawSqlString sql, params object[] parameters)
            {
                using (await Database.GetService<IConcurrencyDetector>().EnterCriticalSectionAsync(default))
                {
                    RawSqlCommand rawSqlCommand = Database.GetService<IRawSqlCommandBuilder>().Build(sql.Format, parameters);
                    return await rawSqlCommand.RelationalCommand.ExecuteScalarAsync(Database.GetService<IRelationalConnection>(), rawSqlCommand.ParameterValues);
                }
            }
  • 相关阅读:
    如何获得RVA(相对虚地址)的值,从而得到一个程序的入口点
    Prism 问题总结一: 在模块中引用公用程序集出错
    Dapper 操作 ACCESS 数据库问题总结
    我国土地招拍挂制度
    [导入]棋味
    [导入]无语
    [导入]心灯
    [导入]寄托
    [导入]视频资源
    [导入]asp.net实现视频截图
  • 原文地址:https://www.cnblogs.com/SpeakHero/p/8944516.html
Copyright © 2011-2022 走看看