当前位置:   article > 正文

sqlsugar对mysql效率高_基于.Net Core 2.0 + SqlSugar ORM + MySql快速实现网站开发

sqlsugar 效率

.Net Core 2.0 (以下简称Core)正式版已经发布有一段时间了, 博主也第一时间尝鲜了, 相比Core 1.0和1.1类库支持方面提高了不少, 开发起来也方便快捷很多了.

废话不多说了, 搭建开始. (PS: 博主使用的的是VS2017最新版本, 操作系统使用的是Windows 10专业版 64位)

Core的环境搭建我就不多说了, 贴个微软的官网, 自己去下载搭建一个就好了. 点我飞机票

一: 新建项目

1283083964524806144.htm

选择.Net Core应用 --> ASP.NET Core Web应用 --> 确定

1283083964524806144.htm

1283083964524806144.htm

1283083964524806144.htm5acd504653ce5f489f1acd8a8274776b.png

环境记得选择Core 2.0的, 新建完成后, 项目结构如下

1283083964524806144.htm398802d57fb63e0d5d96cd67568ecf80.png

629ca3046e229f8e46fc917a008919a5.png

1283083964524806144.htm

大家会觉得很奇怪, 没有以前MVC必须有的Controllers和Views文件夹. 解释一下, 这是Core 2.0 MVC新出的特性, 视图可以不经过控制器处理, 直接显示. 但是有个要求限制, 不经过控制器的试图必须放在Pages文件夹里面, 比如我们刚刚新建的项目下的Pages文件夹, 打开看看

1283083964524806144.htm

会发现有一些默认的页面, 打开Index.cshtml, 第一行代码是@page指令, 这也是不经过控制器的视图必须加的指令, @page指令.

1283083964524806144.htm

其它的和以前的MVC差不多, 就不说了.

我们现在通过NuGet添加SqlSugar ORM的引用, 打开NuGet直接输入sqlsugar搜索就行

由于使用的Core, 所以选择sqlSugarCore版本, 如果是基于.Net Framework开发, 安装sqlSuagr版本即可

e6145dea2728358aeccaa16eb76d62a7.png

这里解释下为什么使用SqlSugar ORM

我使用的是Core环境, 现在直接Core的ORM框架不多, 除了EF和Dapper基本上就没有了, SqlSugar灵活性和效率相比比EF和Dapper高了不少, 易用性也比较高, 所以选择SqlSuagr, 确实是一款不错的ORM框架, 维护更新也挺完美的. 官网贴一下, 有需要的童鞋可以看看文档和介绍  SqlSugar点我

然后再安装MySql.Data, 因为使用的是mysql数据库, 需要这个依奈, 直接NuGet下载安装. PS: 选择预览版, mysql.data支持Core的正式版还没发布, 所以先使用预览版. 如图

1283083964524806144.htm

27e36e51304eb324541b2b8030025351.png

这样子, 我们的环境基本上搭建完毕.  为了更好的使用SqlSugar, 我简单的封装了一个类, 代码如下, 可以参考

/// /// Sugar ORM父类, 封装一些基本的操作

///

/// 旷丽文

public class SugarBase

{

/// /// 获取ORM数据库连接对象(只操作数据库一次的使用, 否则会进行多次数据库连接和关闭)

/// 默认超时时间为30秒

/// 默认为MySql数据库

/// 默认自动关闭数据库链接, 多次操作数据库请勿使用该属性, 可能会造成性能问题

/// 要自定义请使用GetIntance()方法或者直接使用Exec方法, 传委托

///

public static SqlSugarClient DB

{

get

{

return InitDB(30, DBType.MySql, true);

}

}

/// /// 数据库连接字符串, 在配置文件中的connectionStrings节点中添加name为SqlSugar的节点信息即可, 会自动获取

///

public static string DBConnectionString { private get; set; } = Configs.DB_ConnectionString;

/// /// 获得SqlSugarClient(使用该方法, 默认请手动释放资源, 如using(var db = SugarBase.GetIntance()){你的代码}, 如果把isAutoCloseConnection参数设置为true, 则无需手动释放, 会每次操作数据库释放一次, 可能会影响性能, 请自行判断使用)

///

/// 等待超时时间, 默认为30秒 (单位: 秒)

/// 数据库类型, 默认为SQL Server

/// 是否自动关闭数据库连接, 默认不是, 如果设置为true, 则会在每次操作完数据库后, 即时关闭, 如果一个方法里面多次操作了数据库, 建议保持为false, 否则可能会引发性能问题

///

/// 旷丽文

public static SqlSugarClient GetIntance(int commandTimeOut = 30, DBType dbType = DBType.MySql, bool isAutoCloseConnection = false)

{

return SugarBase.InitDB(commandTimeOut, dbType, isAutoCloseConnection);

}

/// /// 初始化ORM连接对象, 一般无需调用, 除非要自己写很复杂的数据库逻辑

///

/// 等待超时时间, 默认为30秒 (单位: 秒)

/// 数据库类型, 默认为SQL Server

/// 是否自动关闭数据库连接, 默认不是, 如果设置为true, 则会在每次操作完数据库后, 即时关闭, 如果一个方法里面多次操作了数据库, 建议保持为false, 否则可能会引发性能问题

/// 旷丽文

private static SqlSugarClient InitDB(int commandTimeOut = 30, DBType dbType = DBType.MySql, bool isAutoCloseConnection = false)

{

var db = new SqlSugarClient(new ConnectionConfig()

{

ConnectionString = SugarBase.DBConnectionString,

DbType = dbType == DBType.SqlServer ? SqlSugar.DbType.SqlServer : SqlSugar.DbType.MySql,

InitKeyType = InitKeyType.Attribute,

IsAutoCloseConnection = isAutoCloseConnection

});

db.Ado.CommandTimeOut = commandTimeOut;

return db;

}

/// /// 执行数据库操作

///

/// 返回值类型

/// 方法体

///

/// 旷丽文

public static Result Exec(Funcfunc, int commandTimeOut = 30, DBType dbType = DBType.MySql)

{

if (func == null) throw new Exception("委托为null, 事务处理无意义");

using (var db = InitDB(commandTimeOut, dbType))

{

try

{

return func(db);

}

catch (Exception ex)

{

throw ex;

}

finally

{

db.Dispose();

}

}

}

/// /// 带事务处理的执行数据库操作

///

/// 返回值类型

/// 方法体

///

/// 旷丽文

public static Result ExecTran(Funcfunc, int commandTimeOut = 30, DBType dbType = DBType.MySql)

{

if (func == null) throw new Exception("委托为null, 事务处理无意义");

using (var db = InitDB(commandTimeOut, dbType))

{

try

{

db.Ado.BeginTran(IsolationLevel.Unspecified);

var result = func(db);

db.Ado.CommitTran();

return result;

}

catch (Exception ex)

{

db.Ado.RollbackTran();

throw ex;

}

finally

{

db.Dispose();

}

}

}

}

/// /// 数据库类型

///

public enum DBType

{

SqlServer = 1,

MySql = 2

}

先写个简单的登录吧, 数据库表自己建, 实体类生成可以使用SqlSugar的DbFirst功能生成, 使用方法查看官网的例子, 特别简单. (SqlSugar真方便)

新建视图和控制器什么的, 就不贴了, 直接贴代码

登录代码

public class HomeController : Controller

{

/// /// 登录页面

///

///

[HttpGet]

public IActionResult Login() => View();

/// /// 登录Ajax方法

///

///

[HttpPost]

public IActionResult LoginFunc(string account,string pwd)

{

var driver = DB.Queryable().Single(f => f.Account == account && f.Pwd == pwd);

if (driver!=null) //存在则登录成功, 写入Cookie

{

Response.Cookies.Append("LoginInfo", driver.ID.ToString()); //这里把用户ID存入Cookie, 标识登录状态

return Content("SUCCESS");

}

else

{

return Content("帐号密码不存在");

}

}

}

这里补充一下Core MVC获取的参数的两种方式, 一种是直接在Action上面写参数, 会自动获取, 如果不这样写的, 就用第二种方式, 和framework获取参数的方式略有不同

如我获取一个叫account的参数, 这样写

var account = string.Empty;

var accountResult = Request.Query.TryGetValue("account", out StringValues accountValue);

if (accountResult)

{

account = accountValue[0];

}

else

{

//获取失败

}

就先写个登录Demo吧

可见Core 2.0对于1.1来说改动还是算大的了, 开发起来也方便多了, 比如自动实现了Cookie, 1.1需要手动添加的

配合SqlSugar ORM使用起来完成开发速度还是非常快的.

以上只是Core MVC的入门, 非常简单的登录Demo, 没有进行任何的逻辑处理和判断, 有需要的童鞋可以根据自己的需求实际开发, 下一篇将使用SqlSugar + MVC 做一套CURD

写的粗糙, 如果有什么不明白的地方, 可以加QQ群一起讨论, QQ群号: 225982985

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/134932
推荐阅读
相关标签
  

闽ICP备14008679号