.netcore项目使用了ORM实体映射的方式,通过操作实体类进行数据库交互。
SQLSugar其中涉及动态表以及动态列的问题,请参考zwb我总结的一点心得,简单明了:
动态表--相同列名不同表,可使用一个实体类映射。查询代码写法:this.Queryable().AS("D_PRJ"+UNITSYS). 增删改查皆可以。
动态列--传统的list.where(p=>p.xx=="zwb")这种lambda表达式的写法已经不能满足 xx是个字符串变量的情况,而通过实体属性反射来处理如下:
list.where(p=>p.GetType().GetProperty("xx").GetValue().ToString()=="aa")在LinQ中好用,但sqlsugar并不支持。那么如何通过sqlsugar解决动态列的问题呢?请大家继续往下看:
http://www.codeisbug.com/Doc/8/1127这是官网示例。代码使用场景:
对List集合的ADD添加的条件之间的关系是and的关系
但当我们想tidi把一些条件用or的关系连接在一起怎么处理?官网中用到了conditionalCollections(){}
这个所谓的集合就相当于sql里的括号,可以将几个条件括在里面,里面的条件可以用or连接&#x