ORM 实现数据库表的增删改查
这次通过反射技术来实现一下数据库表的增删改查对象关系映射(英语:Object Relational Mapping,简称ORM,或O/RM,或O/R mapping)
注:引用时约束了以下几点:
- 数据库表的表名与类的类名一致
- 数据库字段名和类字段名一致
注:如果用的是MySql数据库,有提供好的MySqlhelper非MySql数据库可以参考我写好的SqlHelper
SqlHelper参考位置:http://www.cnblogs.com/fengxuehuanlin/p/5271944.html
1.数据插入封装:
/// <summary>
/// 完成数据的插入
/// 要求:1.数据库表名为类名
/// 2.数据库字段名和类字段名相同
/// </summary>
/// <param name="obj">类的对象</param>
public static void Insert(object obj)
{
StringBuilder Sql = new StringBuilder();
Type type = obj.GetType();
FieldInfo[] fields = type.GetFields();//获取类中所有字段信息,(表中的所有字段)
string[] keys = new string[fields.Length-];//存取字段信息
string[] param = new string[fields.Length-];//存储参数化查询的参数
string[] values = new string[fields.Length-];//每个字段对应的值
MySqlParameter[] sqlParameter = new MySqlParameter[fields.Length-]; //参数化查询
string table = type.Name; //获取类名(表中的表名)
int count = ;
foreach (FieldInfo field in fields)
{
if (field.Name != "id") //过滤掉自增字段id
{
keys[count] = field.Name; //字段名
try
{
param[count] = "@" + (field.GetValue(obj)).ToString(); //参数名
values[count] = (field.GetValue(obj)).ToString(); //字段值
MySqlParameter sqlparam = new MySqlParameter();//进行参数化查询
sqlparam.ParameterName = param[count]; //参数化查询用于替换的名字
sqlparam.Value = values[count]; //对应的值
sqlParameter[count] = sqlparam;
count++;
}
catch(Exception e)
{
throw new Exception(keys[count]+"对象未初始化:"); //数据没有初始化时抛异常
}
}
}
string sqlkey = string.Join(",", keys); //将字段数组转换为字符串
string sqlparamstr = string.Join(",", param); //将参数数组转换字符串
Sql.Append("insert into " + table + " (" + sqlkey + ") values (" + sqlparamstr + ")");
SqlHelper.ExecuteNonQuery(Sql.ToString(), sqlParameter); //通过SqlHelper完成操作
}
2.数据删除封装:
/// <summary>
/// 更具id删除数据
/// </summary>
/// <typeparam name="T">T为类名</typeparam>
/// <param name="id">要删除的字段id</param>
public static void Delete<T>(int id)
{
Type type = typeof(T);
string table = type.Name;//获取表名
StringBuilder Sql = new StringBuilder();
Sql.Append("delete from "+table+" where id=@id");
if (SqlHelper.ExecuteNonQuery(Sql.ToString(), new MySqlParameter("@id", id)) <= )
{
throw new Exception("这条记录不存在");
}
}
3.数据更新封装:
/// <summary>
/// 更新一个字段
/// </summary>
/// <typeparam name="T">T为类名(也就是数据库表)</typeparam>
/// <param name="id">更新哪条数据</param>
/// <param name="name">更新哪个字段</param>
/// <param name="value">字段对应的值</param>
public static void Update<T>(int id,string name,object value)
{
Type type = typeof(T);
string table = type.Name;//获取表名
StringBuilder Sql = new StringBuilder();
Sql.Append("Update " + table + " set "+name+"=@value where id=@id");
MySqlParameter[] param = { new MySqlParameter("@value", value), new MySqlParameter("@id", id) };
if(SqlHelper.ExecuteNonQuery(Sql.ToString(), param)<=)
{
throw new Exception("这条记录不存在");
}
}
4.数据查询封装:
/// <summary>
/// 根据id查询值
/// </summary>
/// <typeparam name="T">T为类名(也就是数据库表)</typeparam>
/// <param name="id"></param>
/// <returns></returns>
public static object Select<T>(int id)where T:new()
{
Type type = typeof(T);
string table = type.Name;//获取表名
StringBuilder Sql = new StringBuilder();
Sql.Append("select *from "+table+" where id=@id");
DataTable tab = SqlHelper.ExecuteQuery(Sql.ToString(), new MySqlParameter("@id", id));
if (tab.Rows.Count <= )
{
//没有查询到数据
return default(T);
}
else if (tab.Rows.Count > )
{
throw new Exception("查询到了多条数据");
}
DataRow row =tab.Rows[];
T obj = new T();
FieldInfo[] fields= type.GetFields();
foreach (FieldInfo field in fields)
{
string Name = field.Name; //获取每一个字段名
object value = row[Name]; //将数据库中读取到的每一个值进行赋值
field.SetValue(obj, value);
}
return obj;
}
ORM 实现数据库表的增删改查的更多相关文章
- DjangoMTV模型之model层——ORM操作数据库(基本增删改查)
Django的数据库相关操作 对象关系映射(英语:(Object Relational Mapping,简称ORM),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换.从效果上说 ...
- django 利用ORM对单表进行增删改查
牛小妹上周末,一直在尝试如何把数据库的数据弄到界面上.毕竟是新手,搞不出来,文档也看不懂.不过没关系,才刚上大学.今晚我们就来解释下,要把数据搞到界面的第一步.先把数据放到库里,然后再把数据从库里拿出 ...
- java-jdbc-mysql:实现数据库表的增删改查
以数据库test下数据表student(sno,sname,ssex,sage,sdept)为例: student表中的已有的所有记录:
- MongoDB 基础命令——数据库表的增删改查——遍历操作表中的记录
分组排序查询最大记录 //对 "catagory" 不等于 null 的数据进行分组查询,且查询结果倒序 db.getCollection('userAccount').aggre ...
- ORM对单表的增删改查
表记录的增加: 1)b = Book(name='python', price=99) b.save() 2)Book.objects.create(name='python', price=99) ...
- 使用Servlet和JSp在浏览器上实现对数据库表的增删改查(新手)
第一步:用户输入网址进入一个登陆界面. 里面要有账号密码输入. 登陆界面链接到登陆的Servlet类中. Servlet类 --> 1.接收参数(账户密码) 2.调用DAO层的 SQL语句 验 ...
- C# - VS2019 通过DataGridView实现对Oracle数据表的增删改查
前言 通过VS2019建立WinFrm应用程序,搭建桌面程序后,通过封装数据库操作OracleHelper类和业务逻辑操作OracleSQL类,进而通过DataGridView实现对Oracle数据表 ...
- MySQL数据库之表的增删改查
目录 MySQL数据库之表的增删改查 1 引言 2 创建表 3 删除表 4 修改表 5 查看表 6 复制表 MySQL数据库之表的增删改查 1 引言 1.MySQL数据库中,数据库database就是 ...
- Django学习笔记--数据库中的单表操作----增删改查
1.Django数据库中的增删改查 1.添加表和字段 # 创建的表的名字为app的名称拼接类名 class User(models.Model): # id字段 自增 是主键 id = models. ...
随机推荐
- JS内存泄漏排查方法——Chrome Profiles
一.概述 Google Chrome浏览器提供了非常强大的JS调试工具,Heap Profiling便是其中一个.Heap Profiling可以记录当前的堆内存(heap)快照,并生成对象的描述文件 ...
- DOMContentLoaded
setTimeout(function(){ alert("settimeout"); },0); EventUtil.addHandler(window, "DOMCo ...
- hdu 1005解题报告
这道题目n的取值范围很大,1 <= n <= 100,000,000.因此肯定是需要优化才能AC. 首先我考虑到时是有没有通项公式,研究了一下,没发现什么东西,突然看到两个1时就想到会不会 ...
- ID3算法(Java实现)
数据存储文件:buycomputer.properties #数据个数 datanum=14 #属性及属性值 nodeAndAttribute=年龄:青/中/老,收入:高/中/低,学生:是/否,信誉: ...
- --@angularJS--一个最简单的指令demo
<!DOCTYPE HTML><html ng-app="app"><head> <title>custom-directiv ...
- 用《VisualStudio命令提示》生成WSDL客户端文件
1.找到vs命令提示符并且以管理员方式打开. 2.输入:wsdl + wsdl文件路径(可以为url).如:“wsdl http://localhost:30373/PDAWebService/SH3 ...
- redis的配置详解
redis 127.0.0.1:6379> CONFIG GET loglevel 1) "loglevel" 2) "notice" Redis 的配置 ...
- 维护网站时碰到的Office组件导入、导出出现的问题
问题一:检索COM 类工厂中CLSID 为 {00024500-0000-0000-C000-000000000046}的组件时失败,原因是出现以下错误: 80070005 解决方法: 1.运行dco ...
- Hadoop权威指南:从Hadoop URL读取数据
[TOC] Hadoop权威指南:从Hadoop URL读取数据 使用java.net.URL对象从Hadoop文件系统读取文件 实现类似linux中cat命令的程序 文件名 HDFSCat.java ...
- uml的图与代码的转换——类图
Uml是我们经常使用的统一建模语言或称标准建模语言.它的图是如何和代码对应的呢?下面我们就来就这个问题讨论一下: 首先是类:uml中的类图是这样的 在这个图中,我们可以看出,这个类图总共分了三行,第一 ...