程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> 開源數據引擎-介紹(附源碼),開源源碼

開源數據引擎-介紹(附源碼),開源源碼

編輯:C#入門知識

開源數據引擎-介紹(附源碼),開源源碼


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

  源碼結構

   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] ASC
11 )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 ID
13         {
14           get;set;
15         }
16         private string _aa;
17         /// <summary>
18         /// [aa]
19         /// </summary>
20         public string aa
21         {
22           set
23           {
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? bb
35         {
36           set
37           {
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? cc
49         {
50           set
51           {
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? ee
63         {
64           set
65           {
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、。。。。。。。。。。


源碼下載

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved