一个简易的ORM框架的实现(一)
一个简易的ORM框架的实现
ORM
ORM---操作数据库---对象关系映射
ORM(Object Relational Mapping)框架采用元数据来描述对象与关系映射的细节。只要提供了持久化类与表的映射关系,ORM框架在运行时就能参照映射文件的信息,把对象持久化到数据库中。
早期数据库操作---ADO.NET
ADO.NET的名称起源于ADO(Active Data Objects),是COM组件库,用于在以往的Mircrosoft技术中访问数据。之所以使用ADO.NET名称,是因为Microsoft希望表明,这是在NET编程环境中优先使用的数据访问接口。
ADO.NET的操作过程
1 连接数据库
2 传递SQL语句
3 数据库执行Sql语句
4 返回执行结果
ADO.NET与ORM的比较
ADO:
- 大量的sql语句---业务不同,sql语句不同
- 需要根据不同的场景编写不同的代码--- 灵活去编写sql语句 --- 提前优化sql语句 --- 提供高性能的sql语句
- 不适合快速开发
- 可编程性--- 更加灵活(对于高级开发,全方位发展的)
- 高性能---原生---接近于底层
ORM: - 上手快
- 不用关注数据库,不关注sql语句,降低了开发的成本
- 关注对象,以对象为核心
- 适合快速开发构建
- 性能有争议
- 生成的sql语句---相对僵化---代码生成器
ORM性能争议
- 二次封装---业务的执行,步骤多一些
2。 映射的过程---必然从类到sql语句变化---类---sql语句---必然会有大量的反射 - sql语句僵化---数据库执行有性能损耗
ADO.NET 的增删改查操作
引入我们所需要的nuget包 System.Data.SqlClient
如果我们记不住我们的链接字符串的时候,我们可以通过

连接到我们的数据库,然后通过数据连接中,找到我们所需要的连接字符串

const string connectString = "Data Source=10.10.33.197;Persist Security Info=True;User ID=sa;Password=********";
using (SqlConnection connection = new SqlConnection(connectString))
{
Console.WriteLine($"状态 {connection.State}");
connection.Open();
Console.WriteLine($"状态 {connection.State}");
connection.Close();
}
增删改查我们主要分为2类
增删改----受影响行数
查询 ----结果集
增加
SqlCommand sqlCommand = connection.CreateCommand();
string sql = @"INSERT INTO
beauty(id,NAME,sex,borndate,phone,photo,boyfriend_id)
VALUES(13,'唐艺昕','女','1990-4-23','18988888888',NULL,2);
";
sqlCommand.CommandText = sql;
int iret=sqlCommand.ExecuteNonQuery();
查询
使用SqlDataReader来获取结果集
SqlCommand sqlCommand = connection.CreateCommand();
string sql = @" SELECT TOP (1000) [Id]
,[ProductId]
,[CategoryId]
,[Title]
,[Price]
,[Url]
,[ImageUrl]
FROM [AdvancedCustomerDB].[dbo].[Commodity]";
sqlCommand.CommandText = sql;
SqlDataReader sqlDataReader=sqlCommand.ExecuteReader();
while (sqlDataReader.Read())
{
Console.WriteLine(sqlDataReader["Id"]);
Console.WriteLine(sqlDataReader["ProductId"]);
Console.WriteLine(sqlDataReader["CategoryId"]);
Console.WriteLine(sqlDataReader["Title"]);
Console.WriteLine("=======================================");
}
使用SqlDataAdapter获取结果集
SqlCommand sqlCommand = connection.CreateCommand();
string sql = @" SELECT TOP (1000) [Id]
,[ProductId]
,[CategoryId]
,[Title]
,[Price]
,[Url]
,[ImageUrl]
FROM [AdvancedCustomerDB].[dbo].[Commodity]";
SqlCommand cmd = connection.CreateCommand();
cmd.CommandText = sql;
cmd.CommandType = System.Data.CommandType.Text;
SqlDataAdapter adptr = new SqlDataAdapter(cmd);
System.Data.DataSet ds = new DataSet();
adptr.Fill(ds, "myds");
DataTable dt = new DataTable();
adptr.Fill(dt);
我们在使用上面的语句的时候就遇到了一个问题,什么问题?
就是sql注入的问题,我们没有防备别人使用SQL语句的情况,那我们如何避免这个问题那?
就是SQL语句的参数化。
SqlCommand sqlCommand = connection.CreateCommand();
string sql = @"INSERT INTO [dbo].[Commodity]
([ProductId]
,[CategoryId]
,[Title]
,[Price]
,[Url]
,[ImageUrl])
VALUES
(@ProductId
,@CategoryId
,@Title
,@Price
,@Url
,@ImageUrl)";
SqlCommand cmd = connection.CreateCommand();
cmd.CommandText = sql;
cmd.CommandType = System.Data.CommandType.Text;
cmd.Parameters.Add(new SqlParameter("@ProductId", "12345798"));
cmd.Parameters.Add(new SqlParameter("@CategoryId", "234"));
cmd.Parameters.Add(new SqlParameter("@Title", "高级进阶课程高级进阶课");
cmd.Parameters.Add(new SqlParameter("@Price", "4799.00"));
cmd.Parameters.Add(new SqlParameter("@Url", "zhaoxiedu.net"));
cmd.Parameters.Add(new SqlParameter("@ImageUrl", "zhaoxiedu.net"));
object insertResult = cmd.ExecuteNonQuery();
事务的问题
using (SqlTransaction transaction = connection.BeginTransaction())
{
try
{
//对于业务上来说,可能同时去操作多次数据库表
//要成功--必须要都得成功
//ACID
//原子性
//一致性 --- 要么都成功 只要有一个失败了,都失败了
//隔离性
//持久性
#region 第一个操作
{
string sql = @"Delete [AdvancedCustomerDB].[dbo].[Commodity] where id >@id";
SqlCommand cmd = connection.CreateCommand();
cmd.Transaction = transaction;
cmd.CommandText = sql;
cmd.CommandType = System.Data.CommandType.Text;
cmd.Parameters.Add(new SqlParameter("@id", 31010));
object deleteResult = cmd.ExecuteNonQuery();
}
#endregion
#region 第二个操作
{
string sql = @"INSERT INTO [dbo].[Commodity]
([ProductId]
,[CategoryId]
,[Title]
,[Price]
,[Url]
,[ImageUrl])
VALUES
(@ProductId
,@CategoryId
,@Title
,@Price
,@Url
,@ImageUrl)";
SqlCommand cmd = connection.CreateCommand();
cmd.Transaction = transaction;
cmd.CommandText = sql;
cmd.CommandType = System.Data.CommandType.Text;
cmd.Parameters.Add(new SqlParameter("@ProductId", "12345798"));
cmd.Parameters.Add(new SqlParameter("@CategoryId", "234"));
cmd.Parameters.Add(new SqlParameter("@Title", "高级进阶课程高级进阶课");
cmd.Parameters.Add(new SqlParameter("@Price", "4799.00"));
cmd.Parameters.Add(new SqlParameter("@Url", "zhaoxiedu.net"));
cmd.Parameters.Add(new SqlParameter("@ImageUrl", "zhaoxiedu.net"));
object insertResult = cmd.ExecuteNonQuery();
}
#endregion
transaction.Commit();
}
catch (Exception ex)
{
transaction.Rollback(); //回滚 可以把之前的操作 全部作废
Console.WriteLine(ex.Message);
}
};
}
一个简易的ORM框架的实现(一)的更多相关文章
- JDBC 学习笔记(十)—— 使用 JDBC 搭建一个简易的 ORM 框架
1. 数据映射 当我们获取到 ResultSet 之后,显然这个不是我们想要的数据结构. 数据库中的每一个表,在 Java 代码中,一定会有一个类与之对应,例如: package com.gerrar ...
- Summer——从头开始写一个简易的Spring框架
Summer--从头开始写一个简易的Spring框架 参考Spring框架实现一个简易类似的Java框架.计划陆续实现IOC.AOP.以及数据访问模块和事务控制模块. ...
- 从零实现一个简易的jQuery框架之二—核心思路详解
如何读源码 jQuery整体框架甚是复杂,也不易读懂.但是若想要在前端的路上走得更远.更好,研究分析前端的框架无疑是进阶路上必经之路.但是庞大的源码往往让我们不知道从何处开始下手.在很长的时间里我也被 ...
- 用Metaclass实现一个精简的ORM框架
存档: # -*- coding: utf-8 -*- class Field(object): def __init__(self, name, column_type): self.name = ...
- 一个简易的服务框架lsf
项目地址:https://github.com/jianliu/lsf 主体思路是利用javaassist实现一个代理类,代理java的接口,实现每一个方法,实现的代码是对每个方法的名称.参数构建一个 ...
- C#基于Mongo的官方驱动手撸一个Super简易版MongoDB-ORM框架
C#基于Mongo的官方驱动手撸一个简易版MongoDB-ORM框架 如题,在GitHub上找了一圈想找一个MongoDB的的ORM框架,未偿所愿,就去翻了翻官网(https://docs.mongo ...
- ORM框架的前世今生
目录 一.ORM简介二.ORM的工作原理三.ORM的优缺点四.常见的ORM框架 一.ORM简介 ORM(Object Relational Mapping)对象关系映射,一般指持久化数据和实体对象的映 ...
- [转帖]ORM框架的前世今生
ORM框架的前世今生 https://www.cnblogs.com/7tiny/p/9551754.html 目录 一.ORM简介二.ORM的工作原理三.ORM的优缺点四.常见的ORM框架 一.OR ...
- Python元类实战,通过元类实现数据库ORM框架
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是Python专题的第19篇文章,我们一起来用元类实现一个简易的ORM数据库框架. 本文主要是受到了廖雪峰老师Python3入门教程的启 ...
- 吉特仓库管理系统-ORM框架的使用
最近在园子里面连续看到几篇关于ORM的文章,其中有两个印象比较深刻<<SqliteSugar>>,另外一篇文章是<<我的开发框架之ORM框架>>, 第一 ...
随机推荐
- c语言实现内存池
概要 所谓内存池,顾名思义和线程池的设计原理是一样的,为了减少频繁申请释放内存而带来的资源消耗,减少释放内存后产生的内存碎片. 设计理念 为了方便管理内存池的设计通常是划分出一定数量的内存块,这些内存 ...
- 《ASP.NET Core 微服务实战》-- 读书笔记(第12章)
第 12 章 设计汇总 微服务开发并不是要学习 C#.Java 或者 Go 编程--而是要学习如何开发应用以适应并充分利用弹性伸缩环境的优势,它们对托管环境没有偏好,并能瞬间启停 换句话说,我们要学习 ...
- 【调试】pstore原理和使用方法总结
什么是pstore pstore最初是用于系统发生oops或panic时,自动保存内核log buffer中的日志.不过在当前内核版本中,其已经支持了更多的功能,如保存console日志.ftrace ...
- 使用SpeechRecognition进行语音识别
操作系统 : CentOS7.7.1908_x64 gcc版本 :4.8.5 Python 版本 : 3.6.8 安装语音识别环境: virtualenv -p /usr/bin/python3 py ...
- sensitive word 敏感词(脏词) 如何忽略无意义的字符?达到更好的过滤效果?
忽略字符 说明 我们的敏感词一般都是比较连续的,比如 傻帽 那就有大聪明发现,可以在中间加一些字符,比如[傻!@#$帽]跳过检测,但是骂人等攻击力不减. 那么,如何应对这些类似的场景呢? 我们可以指定 ...
- k8s-权限管理
目录 1. 身份认证 node节点操作 创建普通用户并授权 1. 生成私钥 2. 生成zhangsan用户证书请求文件 3. 为zhangsan用户颁发证书 4. 创建命名空间及pod 5. 创建角色 ...
- 编译安装c2工具sliver以及python 客户端sdk
背景: 项目需要安装sliver服务端和客户端还有sliver的python sdk: git clone https://github.com/BishopFox/sliver.git cd sli ...
- VS2019 添加三方文件夹遇到的坑
在开发新项目时需要用到一些三方 API,这些三方 API 没有生成 lib,所以我们在 VS 编译器中添加这些三方文件夹的头文件路径后 会出现 ERROR LNK2019 的错误提示,这些提示通常都是 ...
- C++ 线程的学习---线程同步
因为是学习篇,写下是为了个人的学习与理解.故参考其他文章为多. 为什么需要线程同步? 在程序中使用多线程时,一般很少有多个线程能在其生命期内进行完全独立的操作.更多的情况是一些线程进行某些处理操作,而 ...
- Programming Abstractions in C阅读笔记:p293-p302
<Programming Abstractions in C>学习第73天,p293-p302总结,总计10页. 一.技术总结 1.时间复杂度 (1)quadratic time(二次时间 ...