所有文章索引:CYQ.Data 轻量数据层之路 框架开源系列 索引
前言:
从V1.5发布到现在时隔20天了,终于发布2.0版本了,2.0系列版本由于引入多数据库支持,内部结构改动较大。
但是外面调用方式仍保持一致向下兼容,因此若从原来V1.N版本升级到2.N版本,只需要轻轻更换CYQ.Data.DLL即可,界面代码不需要改变。
但是外面调用方式仍保持一致向下兼容,因此若从原来V1.N版本升级到2.N版本,只需要轻轻更换CYQ.Data.DLL即可,界面代码不需要改变。
疑问?
最近26号才刚发布了V1.5.5,怎么才3天又发布了2.0版本?就这么点时间改动就很大,那不是很不稳定?
解疑:
V1.5.5版本是拿V1.5版本的源码直接修改的,只是在原来的基本上修正一些sql2000下的应用bug。
实际发布V1.5.5的时候,V2.0已经发布很久了,只是一直做为抢先体验版本存在。
实际发布V1.5.5的时候,V2.0已经发布很久了,只是一直做为抢先体验版本存在。
版本升级内容:
1:增加支持Access/Oracle数据库,因此目前支持数据为:sql 2000/sql 2005/access/oracle。
2:内置Aop,可以分离权限/操作日志/异常/或者其它sql执行统计等模块进行独立开发。
3:MDataTable 增加2个附属方法:Bind(控件名称)及ToJson();
2:内置Aop,可以分离权限/操作日志/异常/或者其它sql执行统计等模块进行独立开发。
3:MDataTable 增加2个附属方法:Bind(控件名称)及ToJson();
4:MAction 刚新增加调试信息输出属性:DebugInfo
一:目前配置文件配置选项
1:默认数据库链接[必选]:
<add name="Conn" connectionString="数据库链接字符串" providerName="最好写上,不写则从链接字符串里取关键字做分支"/>
providerName选项:
sql 2000/sql 2005:System.Data.SqlClient
access:System.Data.OleDb
oracle:System.Data.OracleClient
providerName选项:
sql 2000/sql 2005:System.Data.SqlClient
access:System.Data.OleDb
oracle:System.Data.OracleClient
2:开启异常日志表配置[可选]:
appSettings节点:<add key="IsWriteLog" value="true"/>
说明:如果不配置此节点,V1.5版本及以上会默认抛出异常。配置为true后,有异常不抛出。
connectionStrings节点:<add name="LogConn" connectionString="Conn"/>
说明:如果日志表和Conn默认是同个数据库,可采取共享链接的写法。
说明:如果不配置此节点,V1.5版本及以上会默认抛出异常。配置为true后,有异常不抛出。
connectionStrings节点:<add name="LogConn" connectionString="Conn"/>
说明:如果日志表和Conn默认是同个数据库,可采取共享链接的写法。
3:开启Aop功能配置[可选]:
appSettings节点:<add key="Aop" value="CYQ.Data.Test,CYQ.Data.Test.MyAop"/>
说明:CYQ.Data.Test为程序集名称;CYQ.Data.Test.MyAop为带完整名称空间的类名
说明:CYQ.Data.Test为程序集名称;CYQ.Data.Test.MyAop为带完整名称空间的类名
4:配置Oracle自增序列名称[可选]:
appSettings节点:<add key="AutoID" value="MyAutoID"/>
说明:默认序列名称为:AutoID
说明:默认序列名称为:AutoID
二:using语法使用说明
有些网友对using语法情有独钟,这里我说明一下相关的使用:
1:using语法简单说明:
using(MAction action=new MAction("表")){业务处理} 等同于=> try{ 业务处理} finally{if(action!=null){action.Disponse();}}
2:using语法注意点:
首先我们要知道,对于using语法,是在业务处理完的最后,才执行Disponse()方法。
因此,如果你的业务处理时间很长,而这些很长的处理逻辑可能跟数据库已没有关系,比如查出数据,然后要根据查出的数据做出很多业务逻辑处理。
那么这种情况下使用using,大括号在哪里结束,就得讲究一下,虽然不影响大局,毕竟滥用也不好。
因此,如果你的业务处理时间很长,而这些很长的处理逻辑可能跟数据库已没有关系,比如查出数据,然后要根据查出的数据做出很多业务逻辑处理。
那么这种情况下使用using,大括号在哪里结束,就得讲究一下,虽然不影响大局,毕竟滥用也不好。
3:MDataTable 新方法Bind语法演示using:
using (MAction action = new MAction(TableNames.Users))
{
action.Select().Bind(rptList);
}
{
action.Select().Bind(rptList);
}
几点说明:
1:Select方法查询查询不到数据时,不再返回null,而是返回new MDataTable()的实例。
2:由于保证了Select不会返回null,因此可以使用其Bind方法来直接绑定rptList控件
3:Bind方法支持的控件类型有:GridView/Repeater/DataList/DataGrid/DataGridView
2:由于保证了Select不会返回null,因此可以使用其Bind方法来直接绑定rptList控件
3:Bind方法支持的控件类型有:GridView/Repeater/DataList/DataGrid/DataGridView
三:枚举生成器V2.0版本发布
这里上一张截图,增加支持Access/Oracle生成枚举。
截图如下:
四:框架及最近辅助工具下载地址
详见:CYQ.Data 轻量数据层之路 bug反馈、优化建议、最新框架下载
结言:
使用本框架进行开发,入门简单,开发效率高,性能优越,更有详尽的API文档,有相关的使用帮助文章、示例文章、更甚有相关的视频教程及辅助工具。
关键还是免费与开源,实在是居家旅行、项目开发、学习研究的必备良品!!!!!!
关键还是免费与开源,实在是居家旅行、项目开发、学习研究的必备良品!!!!!!
附言:
别犹豫了,从你看到此框架的瞬间,加入使用的大军吧,从开始到学会,口述教的话也就仅5分钟,看视频教程,也就10分钟,看文章,顶多就半个多小时。
速学速用:
如果你是学生:用它来开发作品,不仅能提升个人经验值,对将来找工作也是大有帮助。
如果你是企业:用它来开发公司项目,即提高员工开发效率,更能统一开发风格,就算员工流动,新人进来,口述几分钟,也能迅速接手了解整体架构。
如果你是初级开发者:老板整天压着工期,逼着你快速开发交付产品,自己手头写框架又能力用限,网上的其它框架又大又多又难学又难用,咋整?用上此框架,烦脑不再用。
如果你是中级开发者:正在提升阶段,试图自己研发框架,下载源码研究吧,多一份思想也不是什么坏事,还可以进群进行相关讨论,互相提升。
如果你......
速学速用:
如果你是学生:用它来开发作品,不仅能提升个人经验值,对将来找工作也是大有帮助。
如果你是企业:用它来开发公司项目,即提高员工开发效率,更能统一开发风格,就算员工流动,新人进来,口述几分钟,也能迅速接手了解整体架构。
如果你是初级开发者:老板整天压着工期,逼着你快速开发交付产品,自己手头写框架又能力用限,网上的其它框架又大又多又难学又难用,咋整?用上此框架,烦脑不再用。
如果你是中级开发者:正在提升阶段,试图自己研发框架,下载源码研究吧,多一份思想也不是什么坏事,还可以进群进行相关讨论,互相提升。
如果你......
最后:祝大家用的放心,用的省心,用的开心,你的鼓励是我最大的动力。
版权声明:本文原创发表于博客园,作者为路过秋天,原文链接:
http://www.cnblogs.com/cyq1162/archive/2010/09/30/1839336.html