PDF.NET数据开发框架实体类操作实例之在PostgreSQL中操作
创始人
2024-07-26 22:21:39
0

本篇是PDF.NET数据开发框架实体类操作实例之在MySQL中操作的姊妹篇,两者使用了同一个测试程序,不同的只是使用的类库和数据库不同,下面说说具体的使用过程。

1,首先在App.config文件中配置数据库连接字符串:

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

2,定义一个用户实体类:

  1. /*  
  2.  * PDF.NET 数据开发框架  
  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";//标识,自增  
  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";//标识,自增
虽然PostgreSQL有“自增”列,但无法直接取到刚插入的这个自增值,所以需要注释它。

3,根据这个实体类,我们去MySQL定义一个用户表:tb_user,具体过程省略,注意字段“ID”仍然使用自增列(在PostgreSQL中是 serial 类型,但编辑表类型的时候,发现字段是整数类型,不过有了默认值: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.             //参数名字可以加 @符号,例如 @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.             //*************构建 OQL 查询表达式 ******* 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 数组作为条件,适合于多个并列的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.             //*************构建 OQL 查询表达式 ******* end ************  
  40.  
  41.             //查询实体列表  
  42.             var result = EntityQuery.QueryList(q);  
  43.             Console.WriteLine("查询实体集合成功,数量:"+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属性设置值,仍然可以修改实体。

5,编译运行,得到下面的结果:

  1. --OQL to SQL:  
  2. SELECT [ID],[Name],[Age]  
  3. FROM [tb_user]  
  4.    Where  [Age] >= @Age0  
  5.         Order by [Age] asc  
  6. --查询实体集合成功,数量: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等数据库一
  2. 用C++连接MySQL等数据库二
  3. 这些SQLite与SQL差异问题,你遇到过吗
  4. 如何将AS3连接到MySQL数据库上
  5. PDF.NET数据开发框架实体类操作实例之在MySQL中操作

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...