NetUML.DataEngine 數據引擎支持多數據庫,數據訪問引擎采用配置方式,類似ibatis.net底層原理,支持多數據庫連接方式。將來可支持數據庫讀寫分離,讀寫分離配置采用MVC路由機制。
源碼結構

PRoviders.config 配置文件名稱,只需把它放在程序的根目錄下即可。
1 <provider name="OracleManagedDataaccess" 2 descrassemblyName:訪問數據庫的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 GO2、生成“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、。。。。。。。。。。源碼下載
新聞熱點
疑難解答