CYQ.Data 轻量数据层之路 V2.0 震撼惊世 支持多数据库/内置Aop(二十五)

简介:

所有文章索引:CYQ.Data 轻量数据层之路 框架开源系列 索引

 

前言:

从V1.5发布到现在时隔20天了,终于发布2.0版本了,2.0系列版本由于引入多数据库支持,内部结构改动较大。
但是外面调用方式仍保持一致向下兼容,因此若从原来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已经发布很久了,只是一直做为抢先体验版本存在。

 

版本升级内容

复制代码
1:增加支持Access/Oracle数据库,因此目前支持数据为:sql 2000/sql 2005/access/oracle。

2:内置Aop,可以分离权限/操作日志/异常/或者其它sql执行统计等模块进行独立开发。

3:MDataTable 增加2个附属方法:Bind(控件名称)及ToJson();
 
4:MAction 刚新增加调试信息输出属性:DebugInfo
复制代码

 

 

一:目前配置文件配置选项

1:默认数据库链接[必选]:

复制代码
ExpandedBlockStart.gif
< add  name ="Conn"  connectionString ="数据库链接字符串"  providerName ="最好写上,不写则从链接字符串里取关键字做分支" />

providerName选项:
sql 2000/sql 2005:System.Data.SqlClient
access:System.Data.OleDb
oracle:System.Data.OracleClient
复制代码

 

2:开启异常日志表配置[可选]:

ExpandedBlockStart.gif
appSettings节点: < add  key ="IsWriteLog"  value ="true" />  
说明:如果不配置此节点,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为带完整名称空间的类名

 

4:配置Oracle自增序列名称[可选]:

appSettings节点: < add  key ="AutoID"  value ="MyAutoID" />
说明:默认序列名称为:AutoID

 

二:using语法使用说明

 

有些网友对using语法情有独钟,这里我说明一下相关的使用:

 

1:using语法简单说明

using(MAction action=new MAction("表")){业务处理} 等同于=> try{ 业务处理} finally{if(action!=null){action.Disponse();}}

 

2:using语法注意点

首先我们要知道,对于using语法,是在业务处理完的最后,才执行Disponse()方法。
因此,如果你的业务处理时间很长,而这些很长的处理逻辑可能跟数据库已没有关系,比如查出数据,然后要根据查出的数据做出很多业务逻辑处理。
那么这种情况下使用using,大括号在哪里结束,就得讲究一下,虽然不影响大局,毕竟滥用也不好。

 

3:MDataTable 新方法Bind语法演示using:

using  (MAction action  =   new  MAction(TableNames.Users))
{
   action.Select().Bind(rptList);
}

几点说明:

1:Select方法查询查询不到数据时,不再返回null,而是返回new MDataTable()的实例。
2:由于保证了Select不会返回null,因此可以使用其Bind方法来直接绑定rptList控件
3:Bind方法支持的控件类型有:GridView/Repeater/DataList/DataGrid/DataGridView

 

三:枚举生成器V2.0版本发布

这里上一张截图,增加支持Access/Oracle生成枚举。

 

截图如下:

 

 四:框架及最近辅助工具下载地址

详见:CYQ.Data 轻量数据层之路 bug反馈、优化建议、最新框架下载

 

结言:

使用本框架进行开发,入门简单,开发效率高,性能优越,更有详尽的API文档,有相关的使用帮助文章、示例文章、更甚有相关的视频教程及辅助工具。

关键还是免费与开源,实在是居家旅行、项目开发、学习研究的必备良品!!!!!!

 

附言:

复制代码
ExpandedBlockStart.gif
别犹豫了,从你看到此框架的瞬间,加入使用的大军吧,从开始到学会,口述教的话也就仅5分钟,看视频教程,也就10分钟,看文章,顶多就半个多小时。

速学速用:

如果你是学生:用它来开发作品,不仅能提升个人经验值,对将来找工作也是大有帮助。

如果你是企业:用它来开发公司项目,即提高员工开发效率,更能统一开发风格,就算员工流动,新人进来,口述几分钟,也能迅速接手了解整体架构。

如果你是初级开发者:老板整天压着工期,逼着你快速开发交付产品,自己手头写框架又能力用限,网上的其它框架又大又多又难学又难用,咋整?用上此框架,烦脑不再用。

如果你是中级开发者:正在提升阶段,试图自己研发框架,下载源码研究吧,多一份思想也不是什么坏事,还可以进群进行相关讨论,互相提升。

如果你......
复制代码

 

 

最后:祝大家用的放心,用的省心,用的开心,你的鼓励是我最大的动力。

 

 

版权声明:本文原创发表于博客园,作者为路过秋天,原文链接:

http://www.cnblogs.com/cyq1162/archive/2010/09/30/1839336.html

相关文章
|
29天前
|
存储 Oracle 关系型数据库
Dataphin常见问题之想要周期执行任务如何解决
Dataphin是阿里云提供的一站式数据处理服务,旨在帮助企业构建一体化的智能数据处理平台。Dataphin整合了数据建模、数据处理、数据开发、数据服务等多个功能,支持企业更高效地进行数据治理和分析。
|
1月前
|
Java API Apache
使用AOP+反射实现Excel数据的读取
使用AOP+反射实现Excel数据的读取
|
1月前
|
SQL 开发框架 JavaScript
在 Vue 中进行数据持久化时,有哪些常用的数据库框架?
在 Vue 中进行数据持久化时,有哪些常用的数据库框架?
49 3
|
1月前
|
存储 数据管理 数据处理
数据之光:探索数据库技术的演进之路
数据之光:探索数据库技术的演进之路
60 1
|
1月前
|
存储 运维 关系型数据库
数据的力量:构筑现代大型网站之数据库基础与应用
数据的力量:构筑现代大型网站之数据库基础与应用
49 0
|
1月前
|
SQL Java 数据库连接
从来没想到我们会扒拉nohup文件去找我们想要的数据,然后往数据库中添加。。。...
从来没想到我们会扒拉nohup文件去找我们想要的数据,然后往数据库中添加。。。...
17 0
|
1月前
|
SQL 关系型数据库 MySQL
【MySQL 数据库】2、MySQL 的数据控制语言、函数和约束
【MySQL 数据库】2、MySQL 的数据控制语言、函数和约束
29 0
|
1月前
|
NoSQL Java 数据库连接
使用Java实现从数据库查出数据存入Redis,并在查询时先查Redis,如果Redis中没有数据再从数据库中读取
使用Java实现从数据库查出数据存入Redis,并在查询时先查Redis,如果Redis中没有数据再从数据库中读取
355 1
|
5天前
|
存储 关系型数据库 MySQL
如何处理爬取到的数据,例如存储到数据库或文件中?
处理爬取的数据,可存储为txt、csv(适合表格数据)或json(适合结构化数据)文件。若需存储大量数据并执行复杂查询,可选择关系型(如MySQL)或非关系型(如MongoDB)数据库。以MySQL为例,需安装数据库和Python的pymysql库,创建数据库和表,然后编写Python代码进行数据操作。选择存储方式应考虑数据类型、数量及后续处理需求。
13 1
|
6天前
|
SQL 关系型数据库 MySQL
关系型数据库插入数据的语句
使用SQL的`INSERT INTO`语句向关系型数据库的`students`表插入数据。例如,插入一个`id`为1,`name`为&#39;张三&#39;,`age`为20的记录:`INSERT INTO students (id, name, age) VALUES (1, &#39;张三&#39;, 20)。如果`id`自增,则可简化为`INSERT INTO students (name, age) VALUES (&#39;张三&#39;, 20)`。
6 2