博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
EF 中 自定义的参数查询
阅读量:6160 次
发布时间:2019-06-21

本文共 1163 字,大约阅读时间需要 3 分钟。

EF 中如果要用到自定义的参数查询,则如下扩展可以是查询更加方便

public 
static 
class EntityFrameworkDbExtention
    {
        
public 
static IEnumerable<T> SqlQueryParameter <T>(
this System.Data.Entity.Database database, 
string sql, 
object parameters = 
null)
        {
            
if (parameters == 
null
return database.SqlQuery<T>(sql);
            
using (
var tmp_cmd = database.Connection.CreateCommand())
            {
                
var dict = ToDictionary(parameters);
                
int i = 
0;
                
var arr = 
new 
object[dict.Count];
                
foreach (
var one_kvp 
in dict)
                {
                    
var param = tmp_cmd.CreateParameter();
                    param.ParameterName = one_kvp.Key;
                    param.Value = one_kvp.Value ?? DBNull.Value;
                    arr[i] = param;
                    i++;
                }
                
return database.SqlQuery<T>(sql, arr);
            }
        }
        
private 
static IDictionary<
string
object> ToDictionary(
object data)
        {
            
const BindingFlags attr = System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Instance;
            
return data.GetType().GetProperties(attr).Where(property => property.CanRead).ToDictionary(property => property.Name, property => property.GetValue(data, 
null));
        }
    }

var p = db.Database.SqlQueryParameter<ppc_account>(
"
select * from ppc_account where id=2
").FirstOrDefault();

转载于:https://www.cnblogs.com/hujingang/archive/2012/10/18/2729442.html

你可能感兴趣的文章
c#中lock的使用(用于预约超出限额的流程)
查看>>
ODI基于源表时间戳字段获取增量数据
查看>>
并发容器之CopyOnWriteArrayList(转载)
查看>>
什么是AAC音频格式 AAC-LC 和 AAC-HE的区别是什么
查看>>
原创:goldengate从11.2升级到12.1.2
查看>>
Quartz
查看>>
正则表达式的语法规则
查看>>
C#一个关于委托和事件通俗易懂的例子
查看>>
类似于SVN的文档内容差异对比工具winmerge
查看>>
Cause: java.sql.SQLException: The user specified as a definer ('root'@'%') does not exist
查看>>
quratz线程
查看>>
execnet: rapid multi-Python deployment
查看>>
windows修改3389端口
查看>>
关于JavaScript词法
查看>>
FreeSwitch中的会议功能(4)
查看>>
MySQL中创建用户分配权限(到指定数据库或者指定数据库表中)
查看>>
AutoReleasePool 和 ARC 以及Garbage Collection
查看>>
重新想象 Windows 8 Store Apps (9) - 控件之 ScrollViewer 基础
查看>>
乐在其中设计模式(C#) - 提供者模式(Provider Pattern)
查看>>
MVP Community Camp 社区大课堂
查看>>