标签:control .com ddms code 监视 where std 配置信息 lte
介绍
不知道大家在用Dapper
的时候SQL语句是写到哪的,目前看网上的例子都是写到类里面的.
此项目的目的是把SQL语句放到文件(xml)中
目前只是初步版本,只是说明了意图,后面会持续完善和优化
功能说明
一起看看如何使用
首先我们需要一个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语句放到文件中
标签:control .com ddms code 监视 where std 配置信息 lte
原文地址:https://www.cnblogs.com/dudd/p/9778893.html