欢迎投稿

今日深度:

PDF.NET数据开发框架实体类操作实例之在PostgreSQ

PDF.NET数据开发框架实体类操作实例之在PostgreSQL中操作


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

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

  1. <?xml version="1.0" encoding="utf-8" ?> 
  2. <configuration> 
  3.   <connectionStrings> 
  4.     <!--<add name ="default" connectionString ="server=192.168.50.XX;User Id=root;password=XXXX;database=test" providerName="PWMIS.DataProvider.Data.MySQL,PWMIS.MySqlClient"/>--> 
  5.     <add name ="default" connectionString ="server=127.0.0.1;User Id=postgres;password=XXXX;database=Test" providerName="PWMIS.DataProvider.Data.PostgreSQL,PWMIS.PostgreSQLClient"/> 
  6.   </connectionStrings> 
  7. </configuration> 

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<int>("ID"); }  
  28.             set { setProperty("ID", value); }  
  29.         }  
  30.  
  31.         public int Age  
  32.         {  
  33.             get { return getProperty<int>("Age"); }  
  34.             set { setProperty("Age", value); }  
  35.         }  
  36.  
  37.         public string Name  
  38.         {  
  39.             get { return getProperty<string>("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<User>.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<User>.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<T>.Instance 属性的插入、修改、删除方法  
  59.             u.Name = "li si3";  
  60.             u.Age = 15;  
  61.             if (EntityQuery<User>.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<User>.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<T> 的实例对象方法更新实体  
  78.             //只会更新赋值过的属性值  
  79.             EntityQuery<User> eq = new EntityQuery<User>(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语句中的字段名要使用双引号。

www.htsjk.Com true http://www.htsjk.com/shujukugl/17810.html NewsArticle PDF.NET数据开发框架实体类操作实例之在PostgreSQL中操作 本篇是PDF.NET数据开发框架实体类操作实例之在MySQL中操作的姊妹篇,两者使用了同一个测试程序,不同的只是使用的类库和数据库...
评论暂时关闭