PDF.NET数据开发框架实体类操作实例
本篇是
PDF.NET数据开发框架实体类操作实例(MySQL) 的姊妹篇,两者使用了同一个测试程序,不同的只是使用的类库和数据库不同,下面说说具体的使用过程。
1,首先在App.config文件中配置数据库连接字符串:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<connectionStrings>
<!--<add name ="default" connectionString ="server=192.168.50.41;User Id=root;password=hisun;database=test" providerName="PWMIS.DataProvider.Data.MySQL,PWMIS.MySqlClient"/>-->
<add name ="default" connectionString ="server=127.0.0.1;User Id=postgres;password=hisun;database=Test" providerName="PWMIS.DataProvider.Data.PostgreSQL,PWMIS.PostgreSQLClient"/>
</connectionStrings>
</configuration>
2,定义一个用户实体类:
/*
* PDF.NET 数据开发框架
* http://www.pwmis.com/sqlmap
*/
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using PWMIS.DataMap.Entity;
namespace TestMySqlEntity
{
class User:EntityBase
{
public User()
{
TableName = "tb_user";
PrimaryKeys.Add("ID");//主键
//IdentityName = "ID";//标识,自增
PropertyNames = new string[] {"ID","Name","Age" };
PropertyValues = new object[PropertyNames.Length];
}
public int ID
{
get { return getProperty<int>("ID"); }
set { setProperty("ID", value); }
}
public int Age
{
get { return getProperty<int>("Age"); }
set { setProperty("Age", value); }
}
public string Name
{
get { return getProperty<string>("Name"); }
set { setProperty("Name", value,50); }
}
}
}
与MySQL中定义的用户实体类不同,下面这一行代码被注释掉了:
//IdentityName = "ID";//标识,自增 虽然PostgreSQL有“自增”列,但无法直接取到刚插入的这个自增值,所以需要注释它。
3,根据这个实体类,我们去MySQL定义一个用户表:tb_user,具体过程省略,注意字段“ID”仍然使用自增列(在PostgreSQL中是 serial 类型,但编辑表类型的时候,发现字段是整数类型,不过有了默认值:nextval('"User_ID_seq"'::regclass))。
4,编写ORM实体类操作的测试代码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using PWMIS.DataMap.Entity;
using System.Data;
namespace TestMySqlEntity
{
class Program
{
static void Main(string[] args)
{
PWMIS.DataProvider.Data.AdoHelper db = PWMIS.DataProvider.Adapter.MyDB.GetDBHelperByConnectionName("default");
//PWMIS.DataProvider.Data.AdoHelper db = PWMIS.DataProvider.Adapter.MyDB.Instance ;
//MySQL 存储过程测试;
//参数名字可以加 @符号,例如 @pAge1
//DataSet ds1= db.ExecuteDataSet("proc_user1",
// CommandType.StoredProcedure,
// new System.Data.IDataParameter[] { db.GetParameter ("@pAge1",22) });
//
User u = new User();
//*************构建 OQL 查询表达式 ******* begin ************
//查询实体集合
//使用 OQLCompare 对象作为条件
//OQL q = OQL.From(u).Select().Where(new OQLCompare(u).Comparer(u.Age, OQLCompare.CompareType.NoSmaller, 15)).END ;
OQL q = new OQL(u);
//使用OQL2 作为条件对象
q.Select().Where(q.Condition.AND(u.Age, ">=", 15)).OrderBy (u.Age ,"asc");
//使用 QueryParameter 数组作为条件,适合于多个并列的And条件
//q.Select().Where(new QueryParameter[] { new QueryParameter("Age", PWMIS.Common.enumCompare.NoSmaller, 15) }).OrderBy(u.Age, "asc");
Console.WriteLine("OQL to SQL:rn"+q.ToString ());
//*************构建 OQL 查询表达式 ******* end ************
//查询实体列表
var result = EntityQuery<User>.QueryList(q);
Console.WriteLine("查询实体集合成功,数量:"+result .Count );
Console.WriteLine("rnExecuted SQL Text:rn{0}rn", PWMIS.DataProvider.Data.CommandLog.Instance.CommandText);
//查询单个实体
u.Name = "zhang san";
q.Select().Where(u.Name);
Console.WriteLine("OQL to SQL:rn" + q.ToString());
User u1 = EntityQuery<User>.QueryObject(q);
if (u1 != null)
Console.WriteLine("查询单个实体成功!");
Console.WriteLine("rnExecuted SQL Text:rn{0}rn", PWMIS.DataProvider.Data.CommandLog.Instance.CommandText);
//直接使用EntityQuery<T>.Instance 属性的插入、修改、删除方法
u.Name = "li si3";
u.Age = 15;
if (EntityQuery<User>.Instance.Insert(u) > 0)
Console.WriteLine("插入实体成功!"); //将自动为ID属性赋值
Console.WriteLine("rnExecuted SQL Text:rn{0}rn", PWMIS.DataProvider.Data.CommandLog.Instance.CommandText);
//PostgreSQL 没有 @@IDENTITY 变量,所以无法拿到刚才的自增值,注释掉下面的修改方法
//u.Age = 25;
//if (EntityQuery<User>.Instance.Update (u) > 0)
// Console.WriteLine("修改实体成功!");
//Console.WriteLine("rnExecuted SQL Text:rn{0}rn", PWMIS.DataProvider.Data.CommandLog.Instance.CommandText);
User u2 = new User();
u2.Name = "wang wu";
u2.Age = 20;
//使用EntityQuery<T> 的实例对象方法更新实体
//只会更新赋值过的属性值
EntityQuery<User> eq = new EntityQuery<User>(u2);
if (eq.SaveAllChanges() > 0)
Console.WriteLine("更新实体成功!");
Console.WriteLine("rnExecuted SQL Text:rn{0}rn", PWMIS.DataProvider.Data.CommandLog.Instance.CommandText);
Console.Read();
}
}
}
注意上面代码中的这一部分:
//PostgreSQL 没有 @@IDENTITY 变量,所以无法拿到刚才的自增值,注释掉下面的修改方法 虽然注释了修改实体的方法,但只要手工给ID属性设置值,仍然可以修改实体。
5,编译运行,得到下面的结果:
OQL to SQL: SELECT [ID],[Name],[Age] FROM [tb_user] Where [Age] >= @Age0 Order by [Age] asc
查询实体集合成功,数量:3
Executed SQL Text: SELECT "ID","Name","Age" FROM "tb_user" Where "Age" >= @Age0 Order by "Age" asc
OQL to SQL: SELECT [ID],[Name],[Age] FROM [tb_user] Where [Name]=@Name
查询单个实体成功!
Executed SQL Text: SELECT "ID","Name","Age" FROM "tb_user" Where "Name"=@Name
插入实体成功!
Executed SQL Text: INSERT INTO "tb_user"("Name","Age") VALUES (@P0,@P1) 注意:在PostgreSQL中,SQL语句中的字段名要使用双引号。
- Golang语言websocket源码
- 社团划分——Fast Unfolding算法
- 【PSU】AIX 11g RAC自动打GI PSU5
- 详解自动识别验证码,LSTM大显身手
- 智能算法——PageRank
- 【Go 语言社区】Golang 可变参数的使用
- 【Go 语言社区】Golang源码解读之map
- 一则报警信息所折射出来的诸多问题(r9笔记第14天)
- Java面试系列17-编程题-读取服务器字符、实现序列化、计数器、1000阶乘、n出列问题等
- tensorflow(一)windows 10 64位安装tensorflow1.4与基本概念解读tf.global_variables_initializer
- 容灾切换中的数据库宕机问题简单分析(一) (r9笔记第12天)
- Java面试系列14
- linux下搭建django记录笔记,未完稿,节后继续
- Java案例-打印图形与π
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Recommending items to more than a billion people(面向十亿级用户的推荐系统)
- pandas:对字符串类型做差分比较
- pandas:由列层次化索引延伸的一些思考
- 远程过程调用 Java RMI 技术 远程控制
- Real-time Xenomai 3 example 1
- Electron 常见问题收录II
- SQL性能调优技巧
- Linux查看CUDA版本以及cudnn版本号
- 数据结构算法操作试题(C++/Python)——最长有效括号
- 数据结构算法操作试题(C++/Python)——两两交换链表中的节点
- 数据结构算法操作试题(C++/Python)——最大子序和
- 数据结构算法操作试题(C++/Python)——四数之和
- 数据结构算法操作试题(C++/Python)——在排序数组中查找元素的第一个和最后一个位置
- 数据结构算法操作试题(C++/Python)——搜索旋转排序数组
- 数据结构算法操作试题(C++/Python)——最后一个单词的长度