轮子来袭 vJine.Core Orm 之 04_使用进阶
- 框架默认情况下支持"connectionStrings"的配置方式,如《轮子来袭 vJine.Core Orm 之 01_快速入门》所述;
- 框架的进阶设定将支持更为详尽、灵活的配置,而您需要做的只是按照给定的格式增加相应的配置节即可(样例及解释如下)。
<?xml version="1.0"?>
<configuration>
<configSections>
<sectionGroup name="vJine.Net"><!-- 必须制定:格式及内容固定 -->
<section name="OrmConfig" type="vJine.Core.AppConfig`1[[vJine.Core.ORM.OrmConfig, vJine.Core]], vJine.Core"/>
</sectionGroup>
</configSections>
<connectionStrings>
<add name="Default" providerName="System.Data.SqlClient" connectionString="Data Source=.;Initial Catalog=Test;Integrated Security=True"/>
</connectionStrings> <vJine.Net>
<OrmConfig>
<Adapters Active="false">
<!--
由用户指定扩展的Adapter(继承自vJine.Core.ORM.IDbAdapter),
-->
<Adapter Active="true" name="My_Orm_Adapter" pattern="O_My">
<type>vJineCore_QuickStart.My_Orm_Adapter, vJineCore_QuickStart</type>
</Adapter>
</Adapters>
<Connections>
<!--
后续内容会覆盖此前db.name相同的内容,
connectionStrings中的内会在初始配置时会添加到此段, 字段对应关系如下(name->name,providerName->providerName,connectionString->connectionString) db各属性的意义:
.name: new DataManager(string name)中对应的name,默认(new DataManager())为Default,
.providerName:DbProviderFactories用以创建DbProviderFactory;
.connectionString:DbProviderFactory用以连接数据库的连接字符串
.adapter:Adapter配置节对应的name
.host,.port,.user,.password;作为connectionString的配置项目可单独设置、修改,并在新建DataManager实例时替换相应索引值,
即:connectionString = string.format(connectionString,.host,.port,.user,.password);如果不需要,可不必指定。
.adapter:如果指定则按da.adapter查找对应的adapter.name;否则按db.providerName,db.name的顺序匹配adapter.pattern
-->
<db name="O_My_Test" providerName="System.Data.SQLite" adapter="SQLite" host="{0}" port="{1}">
<connectionString>Data Source=default_data.db;Version=3;Pooling=True;Max Pool Size=100;</connectionString>
<user>{2}</user>
<password>{3}</password>
</db> <db name="SQLite" providerName="System.Data.SQLite" adapter="SQLite">
<connectionString>Data Source=default_data.db;Version=3;Pooling=True;Max Pool Size=100;</connectionString>
</db> <db name="MySQL" providerName="MySql.Data.MySqlClient" host="127.0.0.1" port="3306">
<user>root</user>
<password>******</password>
<connectionString>server={0};charset=utf8;User Id={2};Password={3};database=test;Persist Security Info=True</connectionString>
</db>
<db name="Oracle" providerName="Oracle.DataAccess.Client" host="XE">
<user>SYSTEM</user>
<password>******</password>
<connectionString>DATA SOURCE={0};PERSIST SECURITY INFO=True;USER ID={2};Password={3}</connectionString>
</db>
</Connections>
<Converters Active="true">
<!--
类型转换定义,用于引用(用以提供系统默认类型转vJine.Core.ORM.OrmTypeConverter以外的类型转换支持)
-->
<Converter name="sbyte_" type="vJine.Core.ORM.TypeConverter+sbyte_, vJine.Core"/>
</Converters>
<TypeMaps adapter="SQLite">
<!--全局数据类型映射-->
<TypeMap adapter="MSSQL" type="string" SQL_TYPE="varchar(70)" Conv="_对应Converter.name(此处不需要,留空即可)"></TypeMap>
<!--请依据需求指定,系统默认类型映射参见《vJine.Core ORM 数据类型映射》-->
</TypeMaps>
<SchemaMaps Active="true"><!--如果Active="false",则或略此项定义-->
<!--针对表的数据类型映射-->
<Schema Active="true" adapter="SQLite" type="vJineCore_QuickStart.BML.My_Model, vJineCore_QuickStart"><!--如果Active="false",则或略此项定义-->
<Map Active="true" Name="Comments" Alias="Comments" IsNullable="true" TrimString="true" Conv="_对应Converter.name(此处不需要,留空即可)"/><!--如果Active="false",则或略此项定义-->
</Schema>
</SchemaMaps>
</OrmConfig>
</vJine.Net>
</configuration>
除《轮子来袭 vJine.Core Orm 之 01_快速入门》一文中所述的基本增、删、改、查外,您也可以使用如下方式操作:
Class<My_Model>.I insert = new Class<My_Model>.I();
insert
.Into("table_A", "table_B") //不写则默认为类名(My_Model)
.Keys(My_Model._.ID, My_Model._.MyStatus, My_Model._.Qty) //不写则默认为所有公共属性
.Values(new_data); dm.E<My_Model>(insert);
Class<My_Model>.D delete = new Class<My_Model>.D();
delete
.From("table_A", "table_B")
.Where(My_Model._.ID.Like("A%") & (My_Model._.MyStatus == My_Model.Status.Ready | My_Model._.MyStatus == My_Model.Status.Running)); dm.E<My_Model>(delete);
Class<My_Model>.U update = new Class<My_Model>.U(); update
.Update("table_A", "table_B")
.Set(My_Model._.Qty.EQ(My_Model._.Qty + ))
.Where(My_Model._.ID.Like("A%") & (My_Model._.MyStatus == My_Model.Status.Ready | My_Model._.MyStatus == My_Model.Status.Running)); dm.E<My_Model>(update);
Class<My_Model>.Q querier = new Class<My_Model>.Q(); querier
.Select(My_Model._.ID, My_Model._.MyStatus, My_Model._.Qty) //只需选择必要的字段即可
.From("table_A", "table_B", "table_C")
.Where(My_Model._.ID.Like("A%") & (My_Model._.MyStatus == My_Model.Status.Ready | My_Model._.MyStatus == My_Model.Status.Running));
dm.E<My_Model>(querier, container);
3、连接、事务及级联调用:
void transaction(DataManager dm) {
/*
* 此处将DataManager作为传入参数有其特殊的意义
* 在常规的业务逻辑中,经常会碰到多个数据库操作方法之间的调用,
* vJjine.Core ORM考虑的了这种应用,确保了多个方法调用时能共享同一个链接、同一个事物
* 而同时又降低了代码的复杂度
*/
dm.Open(); //打开连接
try {
dm.Begin(); //开始事物
//transaction 的一系列数据库操作
transaction_b(dm); //此处调用transaction_b
dm.Commit(); //此处提交事物
} catch (Exception ex) {
dm.Rollback();
//处理错误
} finally {
dm.Close(); //此处关闭连接
}
}
void transaction_b(DataManager dm) {
dm.Open(); //此处共用transaction方法打开的连接
try {
dm.Begin(); //此处共用transaction方法开启的事物
//transaction_b 的一系列数据库操作
dm.Commit(); //此处并未提交事物
} catch (Exception ex) {
dm.Rollback();
//处理错误
} finally {
dm.Close(); //此处并未关闭连接
}
}
4、关于辅助类:
public partial class _ /*起这个名字是为了方便操作,框架中并没有对此做限制,之所以起这个名字也是借鉴了其他的ORM框架*/
/*不必一定声明在业务模型类内部,可依据团队习惯单独定义,同时也不必每个属性都定义,之定义必要的属性即可(参见Class<>.IDUQ)*/ {
public static readonly Property<My_Model/*包含属性的类*/, string/*需与属性类型完全一致*/> ID = new Property<My_Model/*包含属性的类*/, string>("ID"/*需与属性名完全一致*/);
}
5、关于充血与贫血:
vJine.Core ORM 采用贫血模型,最大程度的保证了框架的非侵入特性,当然您也可以依据你的意愿进行封装。
至此,您已经对vJine.Core ORM框架有了充分的了解,如果有闲暇时间,可以试试亲手操作一下了。
QQ讨论群:115051701,欢迎加入。
轮子来袭 vJine.Core Orm 之 04_使用进阶的更多相关文章
- 轮子来袭 vJine.Core Orm 之 03_架构分析
1.vJine.Core ORM 架构: 如上图所示,vJine.Core ORM的特点如下: 所有操作均以DataManager为核心: DataManager业务部分的增删改查操作依赖于Class ...
- 轮子来袭 vJine.Core Orm 之 02_代码生成
1.下载并安装动软代码生成器: 2.下载vJine.Core.Orm模板: 3.解压模本文件并复制到如下的动软代码生成器模板目录: 4.打开动软代码生成器会看到模板已识别加载: 5.选择模板代码批量生 ...
- 轮子来袭 vJine.Core Orm 之 01_快速体验
vJine.Core 是.Net环境下C#类库,在其包含的众多功能中ORM功能尤为突出,现简介如下. 一.支持的数据库: SQLite, MySQL, MS SQL, Oracle. 二.使用方法: ...
- 轮子来袭 vJine.Core 之 AppConfig<T>
1.引用vJine.Core; 2.定义配置类; using System; using System.Collections.Generic; using System.Text; using Sy ...
- vJine.Core 0.3.0.49 正式发布
nuget: https://www.nuget.org/packages/vJine.Core/ oschina: http://git.oschina.net/vjine/vJine.Core/a ...
- .Net Core ORM选择之路,哪个才适合你 通用查询类封装之Mongodb篇 Snowflake(雪花算法)的JavaScript实现 【开发记录】如何在B/S项目中使用中国天气的实时天气功能 【开发记录】微信小游戏开发入门——俄罗斯方块
.Net Core ORM选择之路,哪个才适合你 因为老板的一句话公司项目需要迁移到.Net Core ,但是以前同事用的ORM不支持.Net Core 开发过程也遇到了各种坑,插入条数多了也特别 ...
- [最新].NET Core ORM 开源项目一览,持续更新
截至2019-05-08共收集27个 .NET Core ORM 开源项目,38个 .NET ORM 开源项目. .NET Core ORM 开源项目收集地址:https://github.com/o ...
- .NET Core 学习资料精选:进阶
.NET 3.0 这个月就要正式发布了,对于前一篇博文<.NET Core 学习资料精选:入门>大家学的可还开心?这是本系列的第二篇文章:进阶篇,喜欢的园友速度学起来啊. 对于还在使用传统 ...
- .Net Core ORM选择之路,哪个才适合你
因为老板的一句话公司项目需要迁移到.Net Core ,但是以前同事用的ORM不支持.Net Core 开发过程也遇到了各种坑,插入条数多了也特别的慢,导致系统体验比较差好多都改写Sql实现. 所以我 ...
随机推荐
- css控制大小写
转换不同元素中的文本: text-transform:uppercase //全大写 text-transform:lowercase //全小写 text-transform:capitalize ...
- 【STL源码学习】细品vector
第一节:vector简介 vector是一种典型的类模板,使用的时候必须进行实例化. vector的数据存储在数组上,支持随机访问迭代器,支持下标操作[]和at操作,支持手动扩容和自动容量增长. ve ...
- 将某个组中的账户移动到新的OU下
将某个组中的账户移动到新的OU下 #定义组名 $groupname = "testg" #定义新的OU名称 $newou = "OU=oo,OU=Admins,dc=dd ...
- zookeeper配置同步zookeeper编程
分布式助手Zookeeper(四) kissyoudyb 2013-12-05 17:41 阅读:33 评论:0 分布式助手Zookeeper(三) kissyoudyb 2013-12-05 ...
- linux 内核之旅
http://www.kerneltravel.net/?p=534 http://mp.weixin.qq.com/mp/homepage?__biz=MzI3NzA5MzUxNA==&hi ...
- android开发问题汇总
android开发问题汇总 一. 无法创建新android项目 在eclipse创建新项目时出现: this template depends on the android support libra ...
- CentOS中操作
在Centos中yum安装和卸载软件的使用方法安装方法安装一个软件时 :yum -y install httpd安装多个相类似的软件时:yum -y install httpd*安装多个非类似软件时 ...
- C#_delegate - Pair<T> & 简单顺序逆序 & 方法委托(在Pair类下)&枚举类型 混搭使用
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- JavaScript中的各种宽高以及位置总结
JavaScript中的各种宽高以及位置总结 在javascript中操作dom节点让其运动的时候,常常会涉及到各种宽高以及位置坐标等概念,如果不能很好地理解这些属性所代表的意义,就不能理解js的运动 ...
- Android打包程序
右击项目->导出export next,完成相关信息填写将得到.apk文件,即可部署到手机上. 第一次: 然后打开目录就可以看到生成的apk,可以发布到各大市场上.