日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
PDF.NET數(shù)據(jù)開發(fā)框架實體類操作實例之在PostgreSQL中操作

本篇是PDF.NET數(shù)據(jù)開發(fā)框架實體類操作實例之在MySQL中操作的姊妹篇,兩者使用了同一個測試程序,不同的只是使用的類庫和數(shù)據(jù)庫不同,下面說說具體的使用過程。

成都創(chuàng)新互聯(lián)公司服務(wù)項目包括云龍網(wǎng)站建設(shè)、云龍網(wǎng)站制作、云龍網(wǎng)頁制作以及云龍網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,云龍網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到云龍省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

1,首先在App.config文件中配置數(shù)據(jù)庫連接字符串:

 
 
 
  1.  
  2.  
  3.    
  4.      
  5.      
  6.    
  7.  

2,定義一個用戶實體類:

 
 
 
  1. /*  
  2.  * PDF.NET 數(shù)據(jù)開發(fā)框架  
  3.  * http://www.pwmis.com/sqlmap  
  4.  */ 
  5. using System;  
  6. using System.Collections.Generic;  
  7. using System.Linq;  
  8. using System.Text;  
  9. using PWMIS.DataMap.Entity;  
  10.  
  11. namespace TestMySqlEntity  
  12. {  
  13.     class User:EntityBase   
  14.     {  
  15.         public User()  
  16.         {  
  17.             TableName = "tb_user";  
  18.             PrimaryKeys.Add("ID");//主鍵  
  19.             //IdentityName = "ID";//標(biāo)識,自增  
  20.             PropertyNames = new string[] {"ID","Name","Age" };  
  21.             PropertyValues = new object[PropertyNames.Length];  
  22.  
  23.         }  
  24.  
  25.         public int ID  
  26.         {  
  27.             get { return getProperty("ID"); }  
  28.             set { setProperty("ID", value); }  
  29.         }  
  30.  
  31.         public int Age  
  32.         {  
  33.             get { return getProperty("Age"); }  
  34.             set { setProperty("Age", value); }  
  35.         }  
  36.  
  37.         public string Name  
  38.         {  
  39.             get { return getProperty("Name"); }  
  40.             set { setProperty("Name", value,50); }  
  41.         }  
  42.     }  
  43. }  

與MySQL中定義的用戶實體類不同,下面這一行代碼被注釋掉了:

 //IdentityName = "ID";//標(biāo)識,自增
雖然PostgreSQL有“自增”列,但無法直接取到剛插入的這個自增值,所以需要注釋它。

3,根據(jù)這個實體類,我們?nèi)ySQL定義一個用戶表:tb_user,具體過程省略,注意字段“ID”仍然使用自增列(在PostgreSQL中是 serial 類型,但編輯表類型的時候,發(fā)現(xiàn)字段是整數(shù)類型,不過有了默認(rèn)值:nextval('"User_ID_seq"'::regclass))。

4,編寫ORM實體類操作的測試代碼:

 
 
 
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. using PWMIS.DataMap.Entity;  
  6. using System.Data;  
  7.  
  8. namespace TestMySqlEntity  
  9. {  
  10.     class Program  
  11.     {  
  12.         static void Main(string[] args)  
  13.         {  
  14.             PWMIS.DataProvider.Data.AdoHelper db = PWMIS.DataProvider.Adapter.MyDB.GetDBHelperByConnectionName("default");  
  15.             //PWMIS.DataProvider.Data.AdoHelper db = PWMIS.DataProvider.Adapter.MyDB.Instance ;  
  16.             //MySQL 存儲過程測試;  
  17.             //參數(shù)名字可以加 @符號,例如 @pAge1  
  18.             //DataSet ds1= db.ExecuteDataSet("proc_user1",   
  19.             //    CommandType.StoredProcedure,  
  20.             //    new System.Data.IDataParameter[] { db.GetParameter ("@pAge1",22) });  
  21.  
  22.               
  23.             //  
  24.             User u = new User();  
  25.  
  26.             //*************構(gòu)建 OQL 查詢表達(dá)式 ******* begin ************  
  27.             //查詢實體集合  
  28.             //使用 OQLCompare 對象作為條件  
  29.             //OQL q = OQL.From(u).Select().Where(new OQLCompare(u).Comparer(u.Age, OQLCompare.CompareType.NoSmaller, 15)).END ;  
  30.  
  31.             OQL q = new OQL(u);  
  32.             //使用OQL2 作為條件對象  
  33.             q.Select().Where(q.Condition.AND(u.Age, ">=", 15)).OrderBy (u.Age ,"asc");  
  34.             //使用 QueryParameter 數(shù)組作為條件,適合于多個并列的And條件  
  35.             //q.Select().Where(new QueryParameter[] { new QueryParameter("Age", PWMIS.Common.enumCompare.NoSmaller, 15) }).OrderBy(u.Age, "asc");   
  36.             Console.WriteLine("OQL to SQL:\r\n"+q.ToString ());  
  37.  
  38.               
  39.             //*************構(gòu)建 OQL 查詢表達(dá)式 ******* end ************  
  40.  
  41.             //查詢實體列表  
  42.             var result = EntityQuery.QueryList(q);  
  43.             Console.WriteLine("查詢實體集合成功,數(shù)量:"+result .Count );  
  44.  
  45.             Console.WriteLine("\r\nExecuted SQL Text:\r\n{0}\r\n", PWMIS.DataProvider.Data.CommandLog.Instance.CommandText);  
  46.  
  47.             //查詢單個實體  
  48.             u.Name = "zhang san";  
  49.             q.Select().Where(u.Name);  
  50.             Console.WriteLine("OQL to SQL:\r\n" + q.ToString());  
  51.             User u1 = EntityQuery.QueryObject(q);  
  52.             if (u1 != null)  
  53.                 Console.WriteLine("查詢單個實體成功!");  
  54.  
  55.             Console.WriteLine("\r\nExecuted SQL Text:\r\n{0}\r\n", PWMIS.DataProvider.Data.CommandLog.Instance.CommandText);  
  56.  
  57.  
  58.             //直接使用EntityQuery.Instance 屬性的插入、修改、刪除方法  
  59.             u.Name = "li si3";  
  60.             u.Age = 15;  
  61.             if (EntityQuery.Instance.Insert(u) > 0)  
  62.                 Console.WriteLine("插入實體成功!"); //將自動為ID屬性賦值  
  63.  
  64.             Console.WriteLine("\r\nExecuted SQL Text:\r\n{0}\r\n", PWMIS.DataProvider.Data.CommandLog.Instance.CommandText);  
  65.  
  66.             //PostgreSQL 沒有 @@IDENTITY 變量,所以無法拿到剛才的自增值,注釋掉下面的修改方法  
  67.             //u.Age = 25;  
  68.             //if (EntityQuery.Instance.Update (u) > 0)  
  69.             //    Console.WriteLine("修改實體成功!");  
  70.  
  71.             //Console.WriteLine("\r\nExecuted SQL Text:\r\n{0}\r\n", PWMIS.DataProvider.Data.CommandLog.Instance.CommandText);  
  72.  
  73.             User u2 = new User();  
  74.             u2.Name = "wang wu";  
  75.             u2.Age = 20;  
  76.  
  77.             //使用EntityQuery 的實例對象方法更新實體  
  78.             //只會更新賦值過的屬性值  
  79.             EntityQuery eq = new EntityQuery(u2);  
  80.             if (eq.SaveAllChanges() > 0)  
  81.                 Console.WriteLine("更新實體成功!");  
  82.  
  83.             Console.WriteLine("\r\nExecuted SQL Text:\r\n{0}\r\n", PWMIS.DataProvider.Data.CommandLog.Instance.CommandText);  
  84.  
  85.             Console.Read();  
  86.         }  
  87.     }  

 注意上面代碼中的這一部分:

 //PostgreSQL 沒有 @@IDENTITY 變量,所以無法拿到剛才的自增值,注釋掉下面的修改方法
雖然注釋了修改實體的方法,但只要手工給ID屬性設(shè)置值,仍然可以修改實體。

5,編譯運行,得到下面的結(jié)果:

 
 
 
  1. --OQL to SQL:  
  2. SELECT [ID],[Name],[Age]  
  3. FROM [tb_user]  
  4.    Where  [Age] >= @Age0  
  5.         Order by [Age] asc  
  6. --查詢實體集合成功,數(shù)量:8  
  7.  
  8. --Executed SQL Text:  
  9. SELECT "ID","Name","Age"  
  10. FROM "tb_user"  
  11.    Where  "Age" >= @Age0  
  12.         Order by "Age" asc  
  13.  
  14. --OQL to SQL:  
  15. SELECT [ID],[Name],[Age]  
  16. FROM [tb_user]  
  17.    Where [Name]=@Name  
  18.  
  19. --查詢單個實體成功!  
  20.  
  21. --Executed SQL Text:  
  22. SELECT "ID","Name","Age"  
  23. FROM "tb_user"  
  24.    Where "Name"=@Name  
  25.  
  26.  
  27. --插入實體成功!  
  28.  
  29. --Executed SQL Text:  
  30. INSERT INTO "tb_user"("Name","Age") VALUES (@P0,@P1)  
  31.  
  32. --更新實體成功!  
  33.  
  34. --Executed SQL Text:  
  35. INSERT INTO "tb_user"("Name","Age") VALUES (@P0,@P1) 

注意:在PostgreSQL中,SQL語句中的字段名要使用雙引號。

原文鏈接:http://www.cnblogs.com/bluedoctor/archive/2011/04/26/2029005.html

【編輯推薦】

  1. 用C++連接MySQL等數(shù)據(jù)庫一
  2. 用C++連接MySQL等數(shù)據(jù)庫二
  3. 這些SQLite與SQL差異問題,你遇到過嗎
  4. 如何將AS3連接到MySQL數(shù)據(jù)庫上
  5. PDF.NET數(shù)據(jù)開發(fā)框架實體類操作實例之在MySQL中操作

文章題目:PDF.NET數(shù)據(jù)開發(fā)框架實體類操作實例之在PostgreSQL中操作
網(wǎng)頁網(wǎng)址:http://m.5511xx.com/article/djhjhii.html