Zoey.Dapper--Dapper扩展之把SQL语句放到文件中
介绍
不知道大家在用Dapper的时候SQL语句是写到哪的,目前看网上的例子都是写到类里面的.
此项目的目的是把SQL语句放到文件(xml)中
目前只是初步版本,只是说明了意图,后面会持续完善和优化
功能说明
- SQL 语句单独存放在文件(xml)中
- 支持配置多文件夹(暂不支持指定具体文件)
- 实时监听文件变化
- 支持多数据库(Dapper 本身就支持多数据,为什么这里说支持多数据呢?后面会讲到)
- 支持读写分离(功能虽然有,但配置看起来不爽,后续应该会优化. 负载平衡算法还未实现)
一起看看如何使用
首先我们需要一个xml文件,如下:
<?xml version="1.0" encoding="utf-8" ?>
<sql xmlns="http://schema.zoey.com/sql" domain="Default">
<sql-query name="Student.GetStudentByID">
<text>
<![CDATA[
SELECT * FROM Student WHERE ID = @ID
]]>
</text>
</sql-query> <sql-command name="Student.UpdateStudentByID">
<text>
<![CDATA[
UPDATE Student SET Age = @Age,Name = @Name WHERE ID = @ID
]]>
</text>
</sql-command>
</sql>
这里我们看下面几点:
sql节点上的domain属性.这里是指定数据库的连接字符串,后面会详细说明- 读写分离就是
sql-query和sql-command节点来判断的 name属性目前是所有文件都不能重复
在
Startup中的ConfigureServices添加如下代码://SQL文件的读取和监视依赖 IFileProvider
var physicalProvider = _env.ContentRootFileProvider;
services.AddSingleton<IFileProvider>(physicalProvider); services.AddZoeyDapperCore(options =>
{
//SQL文件夹的路径 支持多个文件夹
options.Path = new List<string>() { "/Config" };
//监控文件的后缀(默认未 *.*)
options.WatchFileFilter = "*.xml";
//该属性暂时没用
options.StartProxy = false;
})
//添加MSSQLserver
//这里说明一下 该方法是非必要的,下面会说
.AddMSSQLserver(option =>
{
//添加数据库连接字符串
//这里为什么没用配置文件读取,考虑到可能用到(Secret Manager)
//后面可以提供直接从配置文件中读取
option.DatabaseElements = new List<DatabaseElement>()
{
//参数1:唯一名称
//参数2:连接字符串
new DatabaseElement("TESTDB","Data Source=.;Initial Catalog=Test;Integrated Security=True")
};
//此处就是上面提到的 domain 节点
//每个domain对象有个唯一名称(xml文件domain的节点)
//每个domain对象都有 Master(主库) 和 Slave(从库) 的名称(上面配置信息的名称)
option.DomainElements = new List<DomainElement>()
{
new DomainElement()
{
//xml文件domain节点的名称
Name = "Default",
//主库和从库的名称(上面配置信息的名称)
//主库和从库可配多个(负载均衡算法暂没实现)
MasterSlaves = new MasterSlaves("TESTDB","TESTDB")
}
};
});
说明:
- 大家也看到了,此处的配置很是繁琐,上面我也说了,这里应该要优化(但不紧急)
用的时候有两种方式.
当我们没调用
AddMSSQLserver时,在Controller中:public class HomeController : Controller
{
//注入ISqlContext
private readonly ISqlContext _sqlContext;
public HomeController(ISqlContext sqlContext)
{
this._sqlContext = sqlContext;
} public IActionResult Index()
{
List<Student> student;
//获取 Student.GetStudentByID SQL信息
var sql = _sqlContext.GetSqlElement("Student.GetStudentByID");
using (var db = new SqlConnection("Data Source=.;Initial Catalog=Test;Integrated Security=True"))
{
student = db.Query<Student>(sql.CommandText, new
{
ID = 1
});
}
return View(student);
} public IActionResult About()
{
//获取 Student.GetStudentByID SQL信息
var sql = _sqlContext.GetSqlElement("Student.UpdateStudentByID");
using (var db = new SqlConnection("Data Source=.;Initial Catalog=Test;Integrated Security=True"))
{
db.Execute(sql.CommandText, new
{
Age = new Random().Next(100),
Name = "Hello Zoey!",
ID = 1
});
}
return View();
}
}
说明:此种方法只是单纯的获取
SQL信息,没什么特别的.下面我们看第二种:
public class HomeController : Controller
{
//注入 ISqlCommand
private readonly ISqlCommand _sqlCommand;
public HomeController(ISqlCommand sqlCommand)
{
_sqlCommand = sqlCommand;
} public IActionResult Index()
{
//此处直接执行 Query 方法
var student = _sqlCommand.GetSqlElement("Student.GetStudentByID").Query<Student>(new
{
ID = 1
}); return View(student);
}
}
说明:
- 用此种方法必须在
Startup中调用AddMSSQLserver方法 - 实现了读写分离,当然 如果主库和从库连接字符串一样就效果了
- 这就是为什么说支持多数据库的原因了
- 用此种方法必须在
结尾
该项目还是开始阶段,只是个雏形,包括文件的命名都可能是不规范的.希望大家多给意见和建议.
Zoey.Dapper--Dapper扩展之把SQL语句放到文件中的更多相关文章
- sql语句把字段中的某个字符去掉
sql语句把字段中的某个字符去掉 )),'http://demo.m-school.net','') 例如: )),'http://192.168.2.180','') )),'http://zpzx ...
- SQL语句 在一个表中插入新字段
SQL语句 在一个表中插入新字段: alter table 表名 add 字段名 字段类型 例: alter table OpenCourses add Audio varchar(50)alter ...
- MyBatis学习(二)、SQL语句映射文件(2)增删改查、参数、缓存
二.SQL语句映射文件(2)增删改查.参数.缓存 2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id=" ...
- MyBatis学习(二)、SQL语句映射文件(1)resultMap
二.SQL语句映射文件(1)resultMap SQL 映射XML 文件是所有sql语句放置的地方.需要定义一个workspace,一般定义为对应的接口类的路径.写好SQL语句映射文件后,需要在MyB ...
- 二、SQL语句映射文件(1)resultMap
//备注:该博客引自:http://limingnihao.iteye.com/blog/106076 SQL 映射XML 文件是所有sql语句放置的地方.需要定义一个workspace,一般定义为对 ...
- MyBatis学习 之 二、SQL语句映射文件(2)增删改查、参数、缓存
目录(?)[-] 二SQL语句映射文件2增删改查参数缓存 select insert updatedelete sql parameters 基本类型参数 Java实体类型参数 Map参数 多参数的实 ...
- MyBatis学习 之 二、SQL语句映射文件(1)resultMap
目录(?)[-] 二SQL语句映射文件1resultMap resultMap idresult constructor association联合 使用select实现联合 使用resultMap实 ...
- SQL语句获取数据库中的表主键,自增列,所有列
SQL语句获取数据库中的表主键,自增列,所有列 获取表主键 1:SELECT TABLE_NAME,COLUMN_NAME FROM INFORMATION_SCHEMA.KEY_COLUMN_U ...
- 一条SQL语句在MySQL中如何执行的
本篇文章会分析一个 sql 语句在 MySQL 中的执行流程,包括 sql 的查询在 MySQL 内部会怎么流转,sql 语句的更新是怎么完成的. 在分析之前我会先带着你看看 MySQL 的基础架构, ...
随机推荐
- Sentry入门
指令类型: 创建.删除角色: CREATE ROLE sentry_all; droop role admin_role; 角色授权/撤销权限: 数据库级别角色授权 GRANT ALL ON DA ...
- sleep(0)作用
假设现在是 2008-4-7 12:00:00.000,如果我调用一下 Thread.Sleep(1000) ,在 2008-4-7 12:00:01.000 的时候,这个线程会 不会被唤醒?某人的代 ...
- 【转载】Linux 进程调度时间测量
测试Context Switch time(进程上下文切换时间) -------------------------------------------------- 创建两个进程(实时进程) ...
- L2-014. 列车调度(set的使用,最长递增子序列)
L2-014. 列车调度 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 火车站的列车调度铁轨的结构如下图所示. Figure ...
- tomcat 基础知识学习
1: 直接将web项目文件件拷贝到webapps 目录中,Tomcat的Webapps目录是Tomcat默认的应用目录,当服务器启动时,会加载所有这个目录下的应用,所以可以将JSP程序打包成一个 wa ...
- Git 之Windows环境下学习系列
Git .SVN .TFS 相同点 不同点 Git 版本控制 优点: 分布式版本控制.无需联网就能版本提交 开源 缺点 入门学习难度高 SVN 优点: 集中式版本控制. 个人开源 缺点 ...
- [JAVA反序列化DEMO]利用RMI进行反序列化一键启动工具
功能: 命令行启动jar包,用户自定义启动RMI端口.默认内置Apache Commons Collections.只需一键启动即可测试java反序列化漏洞. 启动服务: [root@sevck_v3 ...
- 类型:sqlserver;问题:版本;结果:sqlserver版本区分
LocalDB (SqlLocalDB)LocalDB 是 Express 的一种轻型版本,该版本具备所有可编程性功能,但在用户模式下运行,并且具有快速的零配置安装和必备组件要求较少的特点.如果您需要 ...
- FMX 模态窗体
FMX 模态窗体 dlg := TForm2.Create(nil); dlg.ShowModal(procedure(ModalResult: TModalResult) begin ...
- DAY14-前端之Bootstrap框架
Bootstrap介绍 Bootstrap是Twitter开源的基于HTML.CSS.JavaScript的前端框架. 它是为实现快速开发Web应用程序而设计的一套前端工具包. 它支持响应式布局,并且 ...