SmartSql 入门
入门
安装
Install-Package SmartSql
Install-Package SmartSql.Schema
// 以及相应ADO.NET驱动
从连接字符串创建SmartSql实例
var smartSqlBuilder = new SmartSqlBuilder()
.UseDataSource(DbProvider.SQLSERVER, ConnectionString)
.Build();
从XML中创建SmartSql实例
<?xml version="1.0" encoding="utf-8" ?>
<SmartSqlMapConfig xmlns="http://SmartSql.net/schemas/SmartSqlMapConfig.xsd">
<Settings IgnoreParameterCase="false" ParameterPrefix="$" IsCacheEnabled="true"/>
<Properties>
<Property Name="ConnectionString" Value="Data Source=.;Initial Catalog=SmartSqlTestDB;Integrated Security=True"/>
</Properties>
<Database>
<DbProvider Name="SqlServer"/>
<Write Name="WriteDB" ConnectionString="${ConnectionString}"/>
<Read Name="ReadDb-1" ConnectionString="${ConnectionString}" Weight="100"/>
</Database>
<IdGenerator Type="SnowflakeId">
<Properties>
<Property Name="WorkerIdBits" Value="10"/>
<Property Name="WorkerId" Value="888"/>
<Property Name="Sequence" Value="14"/>
</Properties>
</IdGenerator>
<SmartSqlMaps>
<SmartSqlMap Path="Maps" Type="Directory"/>
</SmartSqlMaps>
</SmartSqlMapConfig>
<?xml version="1.0" encoding="utf-8" ?>
<SmartSqlMap Scope="User" xmlns="http://SmartSql.net/schemas/SmartSqlMap.xsd">
<Statements>
<Statement Id="QueryParams">
<Where>
<IsNotEmpty Prepend="And" Property="Id">
T.Id = @Id
</IsNotEmpty>
<IsNotEmpty Prepend="And" Property="UserName">
T.UserName = @UserName
</IsNotEmpty>
<IsNotEmpty Prepend="And" Property="ExtendedInfo">
T.ExtendedInfo = @ExtendedInfo
</IsNotEmpty>
</Where>
</Statement>
<!--新增-->
<Statement Id="Insert">
INSERT INTO T_User
(
Id,
UserName,
ExtendedInfo
)
VALUES
(
@Id,
@UserName,
@ExtendedInfo
);
Select Scope_Identity();
</Statement>
<!--删除-->
<Statement Id="Delete">
Delete From T_User
Where Id=@Id
</Statement>
<!--更新-->
<Statement Id="Update">
UPDATE T_User
<Set>
<IsProperty Prepend="," Property="UserName">
UserName = @UserName
</IsProperty>
<IsProperty Prepend="," Property="ExtendedInfo">
ExtendedInfo = @ExtendedInfo
</IsProperty>
</Set>
Where Id=@Id
</Statement>
<!--获取数据列-->
<Statement Id="Query" >
SELECT
<IsNotEmpty Prepend="Top" Property="Taken">
(@Taken)
</IsNotEmpty>
T.* From T_User T
<Include RefId="QueryParams" />
<Switch Prepend="Order By" Property="OrderBy">
<Default>
T.Id Desc
</Default>
</Switch>
</Statement>
<!--获取分页数据-->
<Statement Id="QueryByPage" >
Select T.* From T_User T With(NoLock)
<Include RefId="QueryParams" />
Order By T.Id Desc
Offset ((@PageIndex-1)*@PageSize) Rows Fetch Next @PageSize Rows Only;
Select Count(1) From T_User T
<Include RefId="QueryParams" />
</Statement>
<!--获取表映射实体-->
<Statement Id="GetEntity" >
Select Top 1 T.* From T_User T With(NoLock)
<Where Min="1">
<IsNotEmpty Prepend="And" Property="Id">
T.Id=@Id
</IsNotEmpty>
</Where>
</Statement>
</Statements>
</SmartSqlMap>
var smartSqlBuilder = new SmartSqlBuilder()
.UseXmlConfig()
.Build();
SmartSqlBuilder 生命周期
SmartSqlBuilder 的最佳作用域是应用作用域。 可以使用单例模式或者静态单例模式。
IDbSession
函数 | 说明 |
---|---|
Execute | IDbCommand.ExecuteNonQuery,执行返回受影响行数 |
ExecuteScalar | IDbCommand.ExecuteScalar,执行并返回查询返回的ReultSet中第一行的第一列 |
Query | 执行返回实体列表 |
QuerySingle | 执行返回单个实体 |
GetDataTable | 执行返回DataTable |
GetDataSet | 执行返回DataSet |
BeginTransaction | 开启事务 |
CommitTransaction | 提交事务 |
RollbackTransaction | 回滚事务 |
var dbSessionFactory = new SmartSqlBuilder()
.UseXmlConfig()
.Build().GetDbSessionFactory();
using (var dbSession = dbSessionFactory.Open())
{
// Do Somethings
}
ExecuteScalar
var id = DbSession.ExecuteScalar<long>(new RequestContext
{
Scope = nameof(User),
SqlId = "Insert",
Request = new User
{
UserName = "SmartSql"
}
});
Execute
var id = DbSession.Execute(new RequestContext
{
Scope = nameof(User),
SqlId = "Update",
Request = new User
{
Id=1,
UserName = "SmartSql"
}
});
Query
var list = DbSession.Query<User>(new RequestContext
{
Scope = nameof(User),
SqlId = "Query",
Request = new { Taken = 100 }
});
QuerySingle
var entity = DbSession.QuerySingle<User>(new RequestContext
{
Scope = nameof(User),
SqlId = "GetEntity",
Request = new { Id = id }
});
QueryByPage
通过传入 ValueTuple ,将多个返回结果合并。
var result = DbSession.QuerySingle<ValueTuple<IEnumerable<User>, int>>(new RequestContext
{
Scope = nameof(User),
SqlId = "QueryByPage",
Request = new { PageSize = 10, PageIndex = 1 }
});
StoredProcedure
var dbParameterCollection = new SqlParameterCollection();
dbParameterCollection.Add(new SqlParameter
{
Name = "Total",
DbType = System.Data.DbType.Int32,
Direction = System.Data.ParameterDirection.Output
});
RequestContext context = new RequestContext
{
CommandType = System.Data.CommandType.StoredProcedure,
RealSql = "SP_QueryUser",
Request = dbParameterCollection
};
var list = DbSession.Query<User>(context);
dbParameterCollection.TryGetParameterValue("Total", out int total);
IDbSession-CUD
IDbSession 同时提供了CUD扩展函数帮助开发者生成好CUD-SQL,方便开发者直接使用。
Insert
var id = DbSession.Insert<User,long>(userEntity);
Update
var recordsAffected = DbSession.Update<User>(new User
{
Id = id,
UserName = "SmartSql"
});
DyUpdate
DyUpdate 函数的作用是当仅需更新部分字段时,可以使用。
var recordsAffected = dbSession.DyUpdate<User>(new { Id = id, UserName = "SmartSql" });
DeleteById
var recordsAffected = dbSession.DeleteById<User, long>(id);
DeleteMany
var recordsAffected = dbSession.DeleteMany<User, long>(new long[] { id0, id1, id2 });
GetById
var entity = dbSession.GetById<User, long>(id);
SmartSql 入门的更多相关文章
- Angular2入门系列教程7-HTTP(一)-使用Angular2自带的http进行网络请求
上一篇:Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数 感觉这篇不是很好写,因为涉及到网络请求,如果采用真实的网络请求,这个例子大家拿到手估计还要自己写一个web ...
- ABP入门系列(1)——学习Abp框架之实操演练
作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...
- Oracle分析函数入门
一.Oracle分析函数入门 分析函数是什么?分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计 ...
- Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数
上一篇:Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数 之前介绍了简单的路由以及传参,这篇文章我们将要学习复杂一些的路由以及传递其他附加参数.一个好的路由系统可以使我们 ...
- Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数
上一篇:Angular2入门系列教程-服务 上一篇文章我们将Angular2的数据服务分离出来,学习了Angular2的依赖注入,这篇文章我们将要学习Angualr2的路由 为了编写样式方便,我们这篇 ...
- Angular2入门系列教程4-服务
上一篇文章 Angular2入门系列教程-多个组件,主从关系 在编程中,我们通常会将数据提供单独分离出来,以免在编写程序的过程中反复复制粘贴数据请求的代码 Angular2中提供了依赖注入的概念,使得 ...
- wepack+sass+vue 入门教程(三)
十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...
- wepack+sass+vue 入门教程(二)
六.新建webpack配置文件 webpack.config.js 文件整体框架内容如下,后续会详细说明每个配置项的配置 webpack.config.js直接放在项目demo目录下 module.e ...
- wepack+sass+vue 入门教程(一)
一.安装node.js node.js是基础,必须先安装.而且最新版的node.js,已经集成了npm. 下载地址 node安装,一路按默认即可. 二.全局安装webpack npm install ...
随机推荐
- 第十三章——卷积神经网络(CNN)
卷积神经网络(Convolutional neural networks,CNNs)来源于对大脑视觉皮层的研究,并于1980s开始应用于图像识别.现如今CNN已经在复杂的视觉任务中取得了巨大成功,比如 ...
- BZOJ_3942_[Usaco2015 Feb]Censoring_KMP
BZOJ_3942_[Usaco2015 Feb]Censoring_KMP Description 有一个S串和一个T串,长度均小于1,000,000,设当前串为U串,然后从前往后枚举S串一个字符一 ...
- BZOJ_2792_[Poi2012]Well_二分答案
BZOJ_2792_[Poi2012]Well_二分答案 Description 给出n个正整数X1,X2,...Xn,可以进行不超过m次操作,每次操作选择一个非零的Xi,并将它减一. 最终要求存在某 ...
- nodejs-5.1 ejs模板引擎
ejs官方文档:https://ejs.bootcss.com/ 1.什么是 EJS? "E" 代表 "effective",即[高效]. EJS 是一套简单的 ...
- java.lang.ClassNotFoundException: com.mysql.jdbc.Drive
Linux下使用eclipse开发web项目,运行的时候出现 Java.lang.ClassNotFoundException: com.MySQL.jdbc.Driver,解决办法如下: 1.导入M ...
- C#中使用Bogus创建模拟数据
原文:CREATING SAMPLE DATA FOR C# 作者:Bruno Sonnino 译文:C#中使用Bogus创建模拟数据 译者: Lamond Lu 背景 在我每次写技术类博文的时候,经 ...
- Java进阶篇 设计模式之十四 ----- 总结篇
前言 本篇是讲述之前学习设计模式的一个总结篇,其目的是为了对这些设计模式的进行一个提炼总结,能够通过查看看此篇就可以理解一些设计模式的核心思想. 设计模式简介 什么是设计模式 设计模式是一套被反复使用 ...
- Spring Boot入门(四):开发Web Api接口常用注解总结
本系列博客记录自己学习Spring Boot的历程,如帮助到你,不胜荣幸,如有错误,欢迎指正! 在程序员的日常工作中,Web开发应该是占比很重的一部分,至少我工作以来,开发的系统基本都是Web端访问的 ...
- kubernetes实践之二:Kubernetes可视WEB UI Dashboard搭建
Kubernetes可视WEBUI Dashboard搭建 支持浏览器:火狐 一.Dashboard下载地址 git clone https://github.com/kubernetes/kuber ...
- 工程文件csproj使用编译条件指定属性
csproj工程文件中有很多xml格式的属性,比如PropertyGroup.ItemGroup,某些属性操作默认是全部的或者是当前编译条件的而已,当我们想指定某些属性只在某个编译条件下发生时就可以通 ...