反射ORM 三层(for sql server/mysql)
sql server and oracle 不同之处只在于:
1·参数@和:
2·自增和序列
RPROM.cs //(写错愕,应该是RPORM)
RPROM.Insert(p1); //需求:DBS中插入一条数据
约定:
类名要和表名一样
字段名和数据库列名一样
主键的名字必须是Id,必须自动递增,int类型
class RupengROM
{
/// 插入对象
internal static void Insert(Object obj)
{
//获得类名
Type type = obj.GetType();
string className = type.Name;
//获得除id的所有列名
PropertyInfo[] properties = type.GetProperties();
string[] propertyNames = new string[properties.Length - 1]; //存除id的属性名(列名)
string[] propertyAtNames = new string[properties.Length - 1]; //存除id的属性+@名
//获得除id的所有参数
MySqlParameter[] mysqlParameters = new MySqlParameter[properties.Length - 1]; //存除id的参数名
int i = 0;
foreach(PropertyInfo property in properties)
{
if(property.Name!="Id")
{
propertyNames[i] = property.Name;
propertyAtNames[i] = "@" + property.Name;
MySqlParameter mysqlParam = new MySqlParameter();
mysqlParam.ParameterName = "@" + property.Name;
mysqlParam.Value = property.GetValue(obj); //获得指定对象的属性值
mysqlParameters[i] = mysqlParam;
i++;
}
}
string propertyNamesStr = string.Join(",", propertyNames);
string propertyAtNamesStr = string.Join(",", propertyAtNames);
//拼接sql语句
//insert into T_Person(Name,Age) values(@Name,@Age)
StringBuilder sb = new StringBuilder();
sb.Append("insert into T_").Append(className).Append("(").Append(propertyNamesStr).Append(") values(").Append(propertyAtNamesStr).Append(")");
int im = MySqlHelper.ExecuteNonQuery(sb.ToString(), mysqlParameters);
string msg = im > 0 ? "插入成功" : "插入失败";
Console.WriteLine(msg);
}
/// 根据id查询对象
internal static Object SelectById(Type type,int id)
{
string className = type.Name;
//拼接sql语句
//select * from T_Person where Id=@Id
StringBuilder sb = new StringBuilder();
sb.Append("select * from T_").Append(className).Append(" where Id=@Id");
DataTable dt = MySqlHelper.ExecuteQuery(sb.ToString(), new MySqlParameter() { ParameterName = "@Id", Value = id });
if(dt.Rows.Count<=0)
{
return null;
}
else if(dt.Rows.Count>1)
{
throw new Exception("数据库发生异常,存在id=" + id + "的重复数据");
}
else
{
DataRow row = dt.Rows[0];
Object obj = Activator.CreateInstance(type); //动态创建指定类型的实例
PropertyInfo[] propertyInfoes = type.GetProperties();
foreach(PropertyInfo propertyInfo in propertyInfoes)
{
string propertyName = propertyInfo.Name; //属性名就是列名
object value = row[propertyName];
propertyInfo.SetValue(obj, value); //设置指定对象的属性值
}
return obj;
}
}
/// 根据Id更新实例
internal static void UpdateById(Object obj)
{
//获得类名
Type type = obj.GetType();
string className = type.Name;
//获得除id的列名变化形式 "Name=@Name"
PropertyInfo[] propertyInfoes = type.GetProperties();
string[] propertyChanges = new string[propertyInfoes.Length - 1]; //存除id的属性变化形式
MySqlParameter[] mysqlParameters = new MySqlParameter[propertyInfoes.Length]; //存sql参数
int i = 0;
foreach(PropertyInfo propertyInfo in propertyInfoes)
{
string propertyName = propertyInfo.Name;
if (propertyName != "Id")
{
propertyChanges[i] = propertyName + "=@" + propertyName;
i++;
}
MySqlParameter mysqlParam = new MySqlParameter();
mysqlParam.ParameterName = "@" + propertyName;
mysqlParam.Value = propertyInfo.GetValue(obj);
mysqlParameters[i] = mysqlParam;
}
string propertyChangesStr = string.Join(",", propertyChanges);
//拼接sql语句
//update T_Person set Name=@Name,Age=@Age where Id=@Id
StringBuilder sb = new StringBuilder();
sb.Append("update T_").Append(className).Append(" set ").Append(propertyChangesStr).Append(" where Id=@Id");
int im = MySqlHelper.ExecuteNonQuery(sb.ToString(), mysqlParameters);
string msg = im > 0 ? "更新成功" : "更新失败";
Console.WriteLine(msg);
}
/// 根据id删除
internal static void DeleteById(Type type, int id)
{
//获得类名
string className = type.Name;
//拼接sql语句
//delete from T_Person where Id=@Id
StringBuilder sb = new StringBuilder();
sb.Append("delete from T_").Append(className).Append(" where Id=@Id");
int im = MySqlHelper.ExecuteNonQuery(sb.ToString(), new MySqlParameter() { ParameterName = "@Id", Value = id });
string msg = im > 0 ? "删除成功" : "删除失败";
Console.WriteLine(msg);
}
}
反射ORM 三层(for sql server/mysql)的更多相关文章
- SQL Server | Mysql 对表的unique 的实现方式
在ANSI SQL 标准中unique 有两种实现方式 1.是可以插入多个空值.也就是说多个null值看成是互不相同的. 2.是只可以插入一个空值,也主是说把所有的空值看也是相同的. 在SQL Ser ...
- 数据库管理工具神器-DataGrip,可同时管理多个主流数据库[SQL Server,MySQL,Oracle等]连接
前言 DataGrip:Jet Brains出品的一款数据库管理工具(没错,是Jet Brains出品,必属精品).DataGrip整合集成了当前主流数据库(如:SQL Server, MySQL, ...
- SQL Server,MySQL,Oracle三者的区别
SQL Server,MySQL,Oracle三者的区别 2016-10-14 转自:SQL Server,MySQL,Oracle三者的区别 目录 1 Oracle.Sql Server.MySql ...
- Java与SQL Server, MySql, Oracle, Access的连接方法以及一些异常解决
Java与SQL Server, MySql, Oracle, Access的连接方法以及一些异常解决 I. 概述 1.1 JDBC概念 JDBC(Java Database Connectivity ...
- Bootstrap + AngularJS+ Ashx + SQL Server/MySQL
去年年底12月,为适应移动端浏览需求,花了1个月时间学习Bootstrap,并将公司ASP网站重构成ASP.NET. 当时采取的网站架构: Bootstrap + jQuery + Ashx + SQ ...
- 反射ORM 三层(for oracle)
sql server and oracle 不同之处只在于: 1·参数@和: 2·自增和序列 3·oracle使用了存储过程以获得当前插入数据的ID DAL层的ORM using Oracle.Dat ...
- iBatis自动生成的主键 (Oracle,MS Sql Server,MySQL)【转】
iBatis的sqlMap配置文件的selectKey元素有个type属性,可以指定pre或者post表示前生成(pre)还是后生成(post). Oracle设置 <!-- Oracle SE ...
- SQL Server Mysql primary key可更新性分析
SQL Server: 一般来说SQL Server 中表的主键是支持更新操作的.但是如果这个主键是由identity(1,1)这类的方式生成的话它是不可更新的. Mysql : Mysql 中表的主 ...
- SQL Server Mysql 对null值理解的不同
在说到对null值的理解主要是用unique来体现的.也是说null在unique约束看来是一个值还是多个值的问题. 还是开始实验吧. MYSQL create table t(x int ,cons ...
随机推荐
- RewriteRule ^(.*)$ index.php/$1 [QSA,PT,L] 是什么意思?
<IfModule mod_rewrite.c> Options +FollowSymlinks RewriteEngine On RewriteCond %{REQUEST_FILENA ...
- 20145240 《Java程序设计》第十周学习总结
20145240 <Java程序设计>第十周学习总结 教材学习内容总结 网络编程 网络编程就是在两个或两个以上的设备(例如计算机)之间传输数据. 程序员所作的事情就是把数据发送到指定的位置 ...
- processing学习整理---Structure
1.语法介绍:与java很相近,可以认为就是java. 2.运行命令(linux): processing-java --output=/tmp/processing-xx --run --force ...
- vs2010下创建webservice ----第一天(建立项目,以及不连数据库进行加减乘除)
Visual Studio 2010默认采用的框架为.NET Framework4,在这个框架中已找不到直接创建WebService的模板方式了.但VS2010可以创建WebService是毋庸置疑的 ...
- ZooKeeper服务-操作(API、集合更新、观察者、ACL)
操作 create:创建一个znode(必须要有父节点)delete:删除一个znode(该znode不能有任何子节点)exists:测试一个znode是否存在并且查询它的元数据getACL,setA ...
- QT QMimeData类
http://blog.csdn.net/xie376450483/article/details/5863810 QMimeData类提为数据提供一个容器,用来记录关于MIME类型数据的信息 QMi ...
- css3表格样式
<caption> 关于表格存储内容的描述或总结. 1.border-spacing:0;border-spacing 属性设置相邻单元格的边框间的距离(仅用于“边框分离”模式). 2. ...
- ie 元素兼容性总结
css 属性元素 2.z-index 正常按自身层级决定显示顺序,在ie6 7 还需要依赖于父级的层级决定,排布在后边的元素排在前面.后来者居上覆盖前者. IE6,7支持inline元素转换成inli ...
- 命令行下载Baiduyun files
源码 步骤1:先拿到一个插件插件地址1,插件地址2 步骤2:解压并保存 下载的文件中,包含了一个Baidu-PCS的文件夹.然后打开我们的资源管理器.将Baidu-PCS随意移动到一个文件目录下,但文 ...
- 解决:easygui.msgbox("Hello there!")报错:Tcl_Init error: Can't find a usable init.tcl in the following directories问题的解决
今天学习<父与子的编程之旅>,当看到运行第一个gui时(代码如下): import easygui easygui.msgbox("Hello there!") 发现报 ...