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. ...
随机推荐
- 中英文混合字符串截取java
//截取字符串长度(中文2个字节,半个中文显示一个) public String subTextString(String str,int len){ if(str.length()<len/2 ...
- CocoaPods ReactiveCocoa 学习实践一 之 配置环境
1.安装CocoaPods 1.00.参考 CocoaPods 文档 1.01.是否已安装 which pod 1.1.升级gem命令 sudo gem update --system 1.2.切换C ...
- JDBC oracle 错误总结
ORA-28040: No matching authentication protocol jdk:1.8 oracle:12c 使用ojdbc14.jar 报错:ORA-28040: No mat ...
- Zepto swipe 无效(坑)
Zepto 滑动插件 bug Zepto 的 'swipe', 'swipeLeft', 'swipeRight', 'swipeUp', 'swipeDown' 触摸事件在安卓4.4系统中除chro ...
- php将图片以二进制保存到mysql数据库并显示
一.存储图片的数据表结构: -- -- 表的结构 `image` -- CREATE TABLE IF NOT EXISTS `image` ( `id` int(3) NOT NULL AUTO_I ...
- Bootstrap兼容IE8
使用BootStrap3.x写的公司一个响应式项目在IE下面错误百出,经过一番折腾.全部解决了IE8下的兼容问题. 这里汇总一下,希望对大家有所帮助. 1. Bootstrap UI整体在IE8下变窄 ...
- 第6组UI组件:ViewAnimator及其子类
ViewAnimator是一个基类,它继承了FrameLayout,因此它表现出FrameLayout的特征,可以将多个View组件“叠”在一起.ViewAnimator额外增加的功能正如它的名字所暗 ...
- android:在ViewPager中使用Button
最近在项目用用到ViewPager ,其中页面包含有Button,因为之前也有使用个ViewPager ,所以这个也照搬之前的方式,测试后发现点击button无法执行,这个button是在第一页面的默 ...
- 深圳尚学堂:Swift中的“!”和“?”
Swift中的"!"和"?"Swift,苹果于2014年WWDC发布的新开发语言,用于搭建基于苹果平台的应用程序.Swift是一款易学易用的编程语言,而且它还是 ...
- [JQuery]Jquery对象和dom对象
jquery对象是jquery包装dom对象后产生的对象,它们都只能使用各自的方法. 1.定义变量时,通过$来区分: var $variable = jquery对象: var variable = ...