分享
 
 
 

王朝学院·作者佚名  2016-05-21
窄屏简体版  字體: |||超大  

开源数据引擎-介绍(附源码)NetUML.DataEngine 数据引擎支持多数据库,数据访问引擎采用配置方式,类似ibatis.net底层原理,支持多数据库连接方式。将来可支持数据库读写分离,读写分离配置采用MVC路由机制。

源码结构

一、配置介绍PRoviders.config 配置文件名称,只需把它放在程序的根目录下即可。

1 <provider name="OracleManagedDataaccess" 2 description="Oracle, Microsoft provider V1.0.5000.0" 3 enabled="true" 4 default="false" 5 assemblyName="Oracle.ManagedDataAccess, Version=4.121.1.0, Culture=neutral, PublicKeyToken=89b483f429c47342" connectionClass="Oracle.ManagedDataAccess.Client.OracleConnection" 6 commandClass="Oracle.ManagedDataAccess.Client.OracleCommand" 7 parameterClass="Oracle.ManagedDataAccess.Client.OracleParameter" 8 parameterDbTypeClass="Oracle.ManagedDataAccess.Client.OracleDbType" 9 parameterDbTypeProperty="OracleType"10 dataAdapterClass="Oracle.ManagedDataAccess.Client.OracleDataAdapter"11 commandBuilderClass="Oracle.ManagedDataAccess.Client.OracleCommandBuilder"12 usePositionalParameters="false"13 useParameterPrefixInSql="true"14 useParameterPrefixInParameter="false"15 parameterPrefix=":"16 allowMARS="false"17 />

assemblyName:访问数据库的DLL程序集信息,此DLL文件也必须放在程序根目录下。

App.Config 配置数据库连接字符串

<add providerName="oracleManagedDataAccess" name="oracle" connectionString="User ID=d;PassWord=d;Data Source=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=ORCL)));"/>

providerName:采用哪个配置信息访问数据库,这里采用oracleManagedDataAccess的配置。

二、初如化配置在程序启动的时候调用 NetUML.DataAccess.DbHelper.InitDBConfig();

三、使用介绍1、新建表“Class1”

1 /** 创建表[Class1] **/ 2 CREATE TABLE [dbo].[Class1]( 3 [ID] [int] IDENTITY (1, 1) NOT NULL , 4 [aa] [nvarchar](50) NULL , 5 [bb] [datetime] NULL , 6 [cc] [bit] NULL , 7 [ee] [int] NULL , 8 CONSTRAINT [PK_Class1] PRIMARY KEY 9 (10 [ID] ASC11 )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]12 ) ON [PRIMARY]13 GO

2、生成“ClassModel”

1 ///<summary> 2 ///Class1 3 ///<summary> 4 [Table("Class1")] 5 public class ClassModel: NetUML.DataEngine.ActiveEntity 6 { 7 8 /// <summary> 9 /// [ID]10 /// </summary>11 [Key(KeyType.Indentity)]12 public int ID13 {14 get;set;15 }16 private string _aa;17 /// <summary>18 /// [aa]19 /// </summary>20 public string aa21 {22 set23 {24 if (_aa == value) return;25 OnChanged("aa", _aa, value);26 _aa = value;27 }28 get { return _aa;}29 }30 private DateTime? _bb;31 /// <summary>32 /// [bb]33 /// </summary>34 public DateTime? bb35 {36 set37 {38 if (_bb == value) return;39 OnChanged("bb", _bb, value);40 _bb = value;41 }42 get { return _bb;}43 }44 private bool? _cc;45 /// <summary>46 /// [cc]47 /// </summary>48 public bool? cc49 {50 set51 {52 if (_cc == value) return;53 OnChanged("cc", _cc, value);54 _cc = value;55 }56 get { return _cc;}57 }58 private int? _ee;59 /// <summary>60 /// [ee]61 /// </summary>62 public int? ee63 {64 set65 {66 if (_ee == value) return;67 OnChanged("ee", _ee, value);68 _ee = value;69 }70 get { return _ee;}71 }72 }

新建表和生成Model代码都是用DataUML 软件生成的,如下图:

添加、修改、删除数据操作

1 //添加数据 2 ClassModel model = new ClassModel(); 3 model.aa = "ss"; 4 model.bb = DateTime.Now; 5 model.Save(); 6 //修改数据 7 ClassModel model = new ClassModel(); 8 model.ID = 1; 9 model.aa = "bb";10 model.Update();11 // 删除数据12 ClassModel model = new ClassModel();13 model.ID = 1;14 model.Delete();

四、多数据库连接app.config 数据库配置信息如下:

<add providerName="oracleManagedDataAccess" name="oracle" connectionString="User ID=a;Password=a;Data Source=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.0.1)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=ORCL)));"/> <add providerName="sqlServer2.0" name="sqlconnect1" connectionString="Data Source=192.168.0.1;Initial Catalog=t;User Id=sa;Password=sa" /> <add providerName="sqlServer2.0" name="sqlconnect2" connectionString="Data Source=192.168.0.1;Initial Catalog=t;User Id=sa;Password=sa" />

Model的信息如下。

1 ///<summary> 2 ///采用“sqlconnect1” 这个数据库连接字条串进行读写数据 3 ///<summary> 4 [Table("Class1", ConnectionName = "sqlconnect1")] 5 public class ClassModel: NetUML.DataEngine.ActiveEntity 6 { 7 [Key(KeyType.Indentity)] 8 public int ID 9 {10 get;set;11 } 12 }

当读写数据的时候,会采用

<add providerName="sqlServer2.0" name="sqlconnect1" connectionString="Data Source=192.168.0.1;Initial Catalog=t;User Id=sa;Password=sa" />这条数据库连接字符串。

五、后续更新介绍1、增加读写分离配置、多数据库操作配置,无需在类上面定义ConnectionName属性,采用配置方式进行设置2、增加面向对象的概念,类与类之间映射关系,以及级联操作3、增加更丰富的查询操作4、。。。。。。。。。。源码下载

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
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- 王朝網路 版權所有