.NET集成ORM框架HiSql
脚本之家 / 编程助手:解决程序员“几乎”所有问题!
脚本之家官方知识库 → 点击立即使用
一、引言
做.Net这么多年,出现了很多很多ORM框架,比如Dapper,Sqlsugar,Freesql等等。在之前的项目中,用到的ORM框架也大多数是这几个老牌的框架。
不过最近园子关于.NET ORM HiSql的讨论挺多的,本系列将通过不断学习 HiSql官网教程,尝试将之前使用SqlSuger ORM的一个项目,使用HiSql框架实现相关功能,看看hisql能带给我们哪些惊喜。
HiSql GitGub地址
HiSql官网教程
项目介绍:项目是一个通用的后台管理系统,包含菜单管理、权限管理、组织架构、用户管理等等。
数据库采用SqlServer 2016;前端使用Element-UI;后端采用.Net5 Web Api。
二、集成HiSql到项目
1、安装 HiSql 核心包、 HiSql.SqlServer。
2、在项目中新建类文件 HiSqlSetupExtension.cs, 用于注入数据库配置,hisql数据库访问对象。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 | using HiSql; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using System; namespace H.CRM.Action.API.Helper { public static class HiSqlSetupExtension { public static IServiceCollection AddHiSqlSetup( this IServiceCollection services) { //注入HiSqlConfig services.AddTransient<HiSqlConfig>(); //注入HiSqlClient services.AddTransient<HiSqlClient>((d) => { var config = d.GetService<HiSqlConfig>(); var hisql = new HiSqlClient(config); return hisql; }); return services; } } class HiSqlConfig : ConnectionConfig { static readonly NLog.Logger logger = NLog.LogManager.GetLogger( "HiSqlSetup" ); public HiSqlConfig(IConfiguration configuration) { DbType = DBType.SqlServer; DbServer = "HISQL" ; ConnectionString = configuration.GetSection( "ConnectionStrings:Admin" ).Value; Schema = "dbo" ; SqlExecTimeOut = 1000 * 5; AppEvents = new AopEvent() { OnDbDecryptEvent = (connstr) => { //解密连接字段 return connstr; }, OnLogSqlExecuting = (sql, param) => { //sql执行前 日志记录 (异步) #if DEBUG logger.Trace($ "执行前sql:{sql} time:{DateTime.Now.ToString(" yyyy-MM-dd HH:mm:ss ffff ")}" ); #endif }, OnLogSqlExecuted = (sql, param) => { #if DEBUG //sql执行后 日志记录 (异步) logger.Trace($ "执行后sql:{sql} time:{DateTime.Now.ToString(" yyyy-MM-dd HH:mm:ss ffff ")}" ); #endif }, OnSqlError = (sqlEx) => { //sql执行错误后 日志记录 (异步) logger.Error($ "执行错误:{sqlEx.Message} sql:{sqlEx.Sql} time:{DateTime.Now.ToString(" yyyy-MM-dd HH:mm:ss ffff ")}" ); }, OnTimeOut = ( int timer) => { //logger.Trace($"执行超时:{timer} time:{DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss ffff")}"); } }; } } } |
3、在 Startup 中的ConfigureServices方法中,添加 hisql的使用。
4、新建 控制器 HiSqlController,添加初始化方法。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | using Microsoft.AspNetCore.Mvc; using HiSql; using System.Linq; namespace HSMB.Admin.WebApi.Controllers { [Route( "api/[controller]/[action]" )] [ApiController] public class HiSqlController : ControllerBase { private readonly HiSqlClient sqlClient; public HiSqlController( HiSqlClient hiSqlClient ) { this .sqlClient = hiSqlClient; } [HttpGet, HttpPost] public IActionResult Install() { sqlClient.CodeFirst.InstallHisql(); var tables = sqlClient.DbFirst.GetTables().ToList().Where(t=>t.TabName.StartsWith( "H" )); return new JsonResult(tables); } } } |
5、启动项目后,访问 项目地址 http://localhost:8868/api/hisql/Install 初始化hisql。
如图表示初始化成功,同时在数据库也可以看到,系统创建了下图的4个基础表:
- 1.Hi_TabModel #表结构信息主表
- 2.Hi_FieldModel #表结构信息明细表
- 3.Hi_Domain #数据域
- 4.Hi_DataElement #数据元素
到此,项目就完成了HiSql的引入了,后面就可以愉快的使用HiSql各个功能。
到此这篇关于.NET集成ORM框架HiSql的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
微信公众号搜索 “ 脚本之家 ” ,选择关注
程序猿的那些事、送书等活动等着你
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 reterry123@163.com 进行投诉反馈,一经查实,立即处理!
相关文章
asp.net音频转换之.amr转.mp3(利用七牛转换法)
相信很多人都遇到amr格式的音频文件不能直接在网页播放的问题,有人使用QuickTime插件的辅助,下面这篇文章主要给大家介绍了asp.net音频转换之利用七牛转换法将.amr格式转.mp3格式,需要的朋友可以参考借鉴,下面来一起看看吧。2016-12-12CZGL.ProcessMetrics处理监控数据的三种方式介绍
这篇文章介绍了CZGL.ProcessMetrics处理监控数据的三种方式,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-04-04
最新评论