博客
关于我
CYQ.Data V5 MAction新增加SetExpression方法说明
阅读量:421 次
发布时间:2019-03-06

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

需求:

 

 
在之前的版本中,如果你要更新某一个字段的值+1;
 
解决方案:

 

 
1:如果用MAction操作,可能会如下代码:
 
using(MAction action=new MAction(表名))
{
if(action.Fill(id))
{
    action.Set(字段名,action.Get<int>(字段名)+1);
    action.Update();
}
}
 
简单的说,就是需要查询出值,然后再用原值进行相关的操作,用这种代码代价就是要多查一次。
 
 

2:另一种方式高性能的是使用MProc来直接操作Sql语句,可能会如下代码:

 
using(MProc proc=new Proc("Update 表名 set 字段名=字段名+1"))
{
proc.ExeNonQuery();
}
 
用MProc基本是万能的了,直接处理SQL语句和存储过程。。。

 

 
大伙习惯了MAction多,所以希望MAction也有个顺路功能:
 
不过好多人习惯用MAction,都图个方便,连条SQL语句也想省一下。。。
事实上,我本人在多个项目中,也有这种需求,当然最后都是直接使用MProc处理了。
 
很多时候,我一直在寻找一种最优方式,能处理这种值+1,值-1的问题,不过每每看着架构,不好下手,一直没找到切入点和使用方法。
 
 

比如一开始想的:

 
using(MAction action=new MAction(表名))
{
action.Set(字段名,“[字段名]+1”);
action.Update("id=1");
}
 
但是这种方式,实现起来,没想象的简单,而且这值是字符串还是表达式?分不清也说不明,所以一直卡在以何种使用方式上。
 
 

CYQ.Data 框架设计原则:

 
CYQ.Data 框架的设计,很多时候,是先思考使用的方法,再去想怎么实现的,先想象出最简单的使用方式,再去想能不能实现,而不是实现了一个功能,却很难使用。
为此,但网友又对我提出这种需求的要求时,我又花了N个小时,看着代码发呆,每次我思考问题或有某项功能时,我都会看着代码发呆几个小时。。当然是在不停的思考。。
 
 

后来终于设计出最终解决方案:

 
using(MAction action=new MAction(表名))
{
action.Set(字段名,值);
action.SetExpression(“字段名=字段名+1”);
action.SetExpression(“字段名=len(字段名)+1”);
action.Update();
}
 
 

通过增加一个表达式方法,基本上有点万能了,事实在后端,组成的Update语句大体为:

 
update 表名 set 表达式,字段名=@字段名 where ...
 
 

简单说,就是表达式只是简单的被附加到原来的set的后面,最终被组装成SQL执行,当然了,如果你想高级点用参数化也是可以的。

 
            using (MAction action = new MAction("Blog_Class"))
            {
                action.SetExpression("count=count+@Value");//表达式升级带参数化。
                action.SetPara("Value", 2, DbType.Int32);//设置参数化值
                action.Update();
            }
 
 

到此,基本上有表达存在,可以处理N种不同的需求了,方便性提升了不少。

 

补充: 

不小心把文章“只允许注册用户访问”给打上勾了,结果发现注册用户的阅读数仅88,根据统计,还有近27个是为了看文章被逼登陆了一下。

周末的行情访问量这么低?大伙都跑哪去偷情了?

 

转载地址:http://vuzuz.baihongyu.com/

你可能感兴趣的文章
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
查看>>
NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
查看>>