应无所住,而生其心
排名
1
文章
845
粉丝
110
评论
162
net core webapi post传递参数
庸人 : 确实坑哈,我也是下班好了好几次,发现后台传递对象是可以的,但...
百度编辑器自定义模板
庸人 : 我建议换个编辑器,因为现在百度富文本已经停止维护了,用tinymec...
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术

表达式树解析简单sql条件语句

5221人阅读 2019/5/29 11:55 总访问:4885482 评论:0 收藏:0 手机
分类: .NET



一个条件类的表达式树的body一般分为三个部分。左边的属性名,中间的判断符号,右边的值。

如图: 



我们要把这类的表达式树解析成sql语句条件,只需要拿到左边,中间,右边的值就行

比如这样的一个

  1. Expression<Func<UserInfo, bool>> func = a => a.UserName == "xx";

我们解析成where UserName='xx' 即可。代码如下,分别解析左边,中间,右边即可

  1. BinaryExpression binaryExpression = func.Body as BinaryExpression;
  2. //处理左边的内容
  3. MemberExpression memberExpression = binaryExpression.Left as MemberExpression;
  4. string value = memberExpression.Member.Name;
  5. string paramter = " where " + value;
  6. //中间
  7. if (binaryExpression.NodeType == ExpressionType.Equal)
  8. {
  9.     paramter += " = ";
  10. }
  11. if (binaryExpression.NodeType == ExpressionType.GreaterThan)
  12. {
  13.     paramter += " > ";
  14. }
  15. if (binaryExpression.NodeType == ExpressionType.GreaterThanOrEqual)
  16. {
  17.     paramter += " >= ";
  18. }
  19. if (binaryExpression.NodeType == ExpressionType.LessThan)
  20. {
  21.     paramter += " < ";
  22. }
  23. //右边
  24. ConstantExpression constantExpression = binaryExpression.Right as ConstantExpression;          
  25. object right = "'" + constantExpression.Value + "'";
  26. paramter += right;

效果如下:



解析的时候如果不知道,左边,右边具体是什么类型,可以直接调试的时候进行看类型就行

比如你不知道这里的Left,Right什么类型,点击进去看就知道了

比如我们看看Left的,明显就是Member类型

看到类型就可以转换成具体的类型,就很方便解析了,转换成MemberExpression即可

  1. //处理左边的内容
  2. MemberExpression memberExpression = binaryExpression.Left as MemberExpression;
  3. string value = memberExpression.Member.Name;


欢迎加群讨论技术,群:677373950(满了,可以加,但通过不了),2群:656732739

评价

如何修改重置MD5加密后的sql用户密码

二次开发时,要加一个忘记密码的功能,后台写了修改密码的方法,数据库执行也修改成功,但是登录一直提示密码错误。之所以...

sql Server的几种分页方式和效率

--topnotin方式 selecttop条数*fromtablename whereIdnotin(selecttop条数*页数Idfromtablename) --ROW_NUMBER()O...

Mysql主从复制+读写分离

使用Mysql读写分离和主从复制的原因:*单台MySQL服务器的安全性,高可用性,高并发都是不满足实际的生产需要。介绍:1.MySQ...

sql Server 中使用游标

--声明一个游标 DECLAREMyCursorCURSOR FORSELECTTOP5FBookName,FBookCodingFROMTBookInfo//定义一个叫MyCursor的游标,...

Mysql控制台插入中文数据报错1366解决

计算机配置: windows系统.数据库:MySQL5.5.如图 : 下图为表结构信息:通过 show full columns from userinfo;查询所得 na...

sqlserver order by

order by 字段名order by 第几个字段(整形)order by 排序:order by 字段名:通过字段名指定的字段排序 order by 字段数...

sqlserver保障远程连接的安全性

如果是只读的话建个视图,建个普通用户只对该视图进行读。读写的话就只能自己在加一层代理服务,由代理来进行读写,各客户...

sqlerver添加用户与授权

添加用户安全性--&gt;登录名,然后右键新建登录名就可以了然后填写好相关信息就可以了右键属性,用户映射可以选择该用户可...

Mysql 游标创建

游标:可以来存储一个结果集,可以通过遍历来访问到每一个数据需求:分表数据。 把一张表的数据根据需求分离,创建不同的表...

没有为 sql 缓存通知启用数据库

C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\aspnet_regsql -S 数据库IP -U 登录名 -P 密码 -d 数据库名称 -t 表名 -et

sqlserver约束

添加表后操作约束--删除约束 altertableaj_testdropconstraintCK__aj_test__userAge__5EBF139D --为表aj_test添加默认...

c sql简单参数化写法

防止sql 注入的,简单参数化写法publicboolLogin(string_username,string_password) { using(SqlConnectionconn=newSqlCo...

mysql 存储过程报错:delimiter

最近刚学sql,学到了存储过程,每当练习的时候就一直出现问题。 现在记录CREATEPROCEDUREproc_out(OUTstuidINT) begin se...

Mysql 视图的(增删改 查)

要显示视图的定义,需要在SHOWCREATEVIEW子句之后指定视图的名称, 我们先来创建几张表,完事后在进行演示:--用户信息表...