王朝网络
分享
 
 
 

分享刚出炉的ORM框架XLinq

王朝学院·作者佚名  2016-05-20  
宽屏版  字体: |||超大  

分享刚出炉的ORM框架XLinq吐嘈忙活了一个多月,XLinq总算"能用"了,BUG总算"少点"了,准备真正替代EF了,现在已经初步在自己的项目中使用了

EF这家伙,优点不少,缺点也不少,我就扯几个最让我头大的缺点(或许这里面的缺点是因为我不会用)

必须将所有实体一次写完整,不能通过DbContext.Set<T>方法动态加载实体 NoLock,硬伤啊,貌似就算用事务然后配置成ReadUncommited也不行 EF支持的LINQ各种坑,简单说几个 .Where(x=>x.LastLogin==DateTime.Now.Date),很简单很常用的代码么,但EF就是不支持 .Where(x=>x.Name==null),看起来好像没问题,但EF却翻译成了where name=null,坑货 左连接!不说实现左连接那郁闷的写法,郁闷的是EF不一定会给那种写法翻译成左连接 第三点吐嘈完毕 已删除性能,其实性能这个好像也没那么差,测试过查询16万数据,近一百个字段,尼玛居然16秒就搞定了···· 暂时想不起来

分享吐嘈EF的人也不少了,我再这么就吐嘈两下完事的话有点没事找事···

所以,针对上面这些坑,我找了很多的ORM(其实好像也不多),试过alinq、dbentry.net,alinq不说,收费的,用不起···后面这个的话,当时被坑多了,就没用过了,对了,还有SOD,大神深蓝医生写的···

然而我自己也曾写过支持LINQ的ORM,但那代码渣的够可以,不过总算写过,知道些原理,其实更多的是为了锻炼,毕竟要支持LINQ的话,难度是比较大的,所以这一次又再一次自己写,功能从简单起见,主要有以下功能

支持简单的LINQ查询,多表连接查询(不支持任意形式的嵌套查询) LINQ一旦写复杂了,确实要生成高性能的SQL非常难,因为就算生成能执行的sql都比较难。我更倾向于将业务拆分,变成简单的LINQ语句能完成的功能。嵌套查询或许以后会支持,但到时候估计就是一堆坑

支持动态加载实体 不需要事先在DbContext里面把实体写好,事实上什么都不写都行,主要是为了便于封装数据层,否则的话我每添加一张表都不得不去DbContext里面加一个实体

支持在LINQ中调用方法和属性,例如.Where(x=>Convert.ToBoolean(x.IsEnabled)) 上面这个写法在EF中是绝对不支持的,另外还支持Date属性访问

多数据库支持 目前只支持了sqlite和sql server 2008 r2,应该说只要sql server 2008 r2支持了,那就可以部分支持其他sql server数据库了

支持自己编写翻译成sql的代码(未测试) 可以自定义生成自己想的sql

支持最小化配置,最小仅需要一个连接字符串 说这个我又要说java了,连hello world都没跑起来却搞了三天的配置,多麻烦!

基本兼容EF的使用方法 降低学习成本

不需要查询,直接更新和删除数据 调用的方式和EntityFramework Exnteded类似,这也算是EF的又一个硬伤

支持NOLock 其他我说漏掉的 使用方法配置文件 这里只说最小化配置

建立数据库 我随便建的xlinq数据库,建了一个Users表,有两个字段,Id和Username,其中Id为自增并且是主键

建立实体

测试插入 终于到这儿了

怎么的,这跟EF的写法不是一模一样的?

运行结果:

测试查询 为什么要把插入放前面?因为插入了之后才有数据查询

运行结果:

测试更新 更新有两种方法,先查询再更新和直接更新

第一种:

运行结果:

第二种:

运行结果:

测试删除 删除也有查询后删除和直接删除两种,这里只说直接删除

NOLOCK

后记看着挺简单的基本功能,但做起来真是一把辛酸泪。计划中还有性能测试的,不过先看有多少人关注吧!

如果想讨论与此相关技术或者索取源码,请进QQ群74522853,答案XLinq

测试源码:http://files.cnblogs.com/files/wzxinchen/XlinqDemo.zip

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
>>返回首页<<
推荐阅读
 
 
频道精选
静静地坐在废墟上,四周的荒凉一望无际,忽然觉得,凄凉也很美
© 2005- 王朝网络 版权所有