net core Webapi基础工程搭建(六)——数据库操作_Part 2
前言
昨天是写着写着发现,时间不早了,已经养成了晚上下班抽时间看看能写点儿啥的习惯(貌似),今天实在是不想让昨天没做完的事情影响,所以又坐下,沉下心(周末了),开始把数据库这块儿的补充完整。
昨天已经介绍过大部分的东西,包括方法封装也是基本的展示了下,实际上应该先介绍这一篇,从怎么用来引导封装类库,但是既然写都写出来了就不想再调整了,今天就主要说下怎么实际使用方法吧,需要查看具体使用的类库可查看net core Webapi基础工程搭建(六)——数据库操作_Part 1。(懒的不能行)
开始
闲话不多说,Service层搞起,新建两个文件夹,一个Interfaces,一个Implements,另外顺带新建个Common的文件夹,把上一篇的三个类放进去(纯粹是看的,归类,放不放不影响使用)。
上一篇我们创建了一个StudentEntity这个对象,忘了的朋友可以去看下。
新建一个IStudentService接口,继承IBaseService
public interface IStudentService : IBaseService<StudentEntity>
{
}
新建一个StudentService实现类,继承BaseService,实现IStudentService
public class StudentService : BaseService<StudentEntity>, IStudentService
{
}
好了,完了,回家睡觉吧。
使用
如果你看到上面的直接走了,对不起,娱乐一下,做开发千万不敢像乌鸦学盖房子,没听过自行度娘,我也不会讲故事。
我们需要在StartUp这里将接口与实现关联,有些博客会介绍自动关联用于解耦,需要也可以自行百度。
补充说明,昨天好像忘记在WebApi工程引入Service与Entity两个工程了,见谅见谅,特此补充。
这里我在Service项目下Common下新建Depends文件夹,新建一个类ServiceInjection,在这统一放接口与实现的对应关系。
public class ServiceInjection
{
public static void ConfigureRepository(IServiceCollection services)
{
services.AddSingleton<IStudentService, StudentService>();
}
}
对于依赖注入,这里简短穿插几句,后续有新的感受会再补充。
方法 | 说明 |
---|---|
Transient | 每一次调用都会创建一个新的实例 |
Scoped | 一个作用域中只实例化一个 |
Singleton | 整个应用程序生命周期以内只创建一个实例 |
然后我们在StartUp的ConfigureServices最前面加上这句话,这里在构造函数加上这句,用途就是由AprilConfig来统一接管配置信息。
public Startup(IConfiguration configuration)
{
...之前的东西
AprilConfig.InitConfig(configuration);
}
public void ConfigureServices(IServiceCollection services)
{
ServiceInjection.ConfigureRepository(services);
...之前的东西
}
当然对应要有接收的方法。
public class AprilConfig
{
public static IServiceProvider ServiceProvider;
public static IConfiguration Configuration;
public static void InitConfig(IConfiguration _configuration)
{
Configuration = _configuration;
}
}
好了,所有的都写好后,我们继续拿万恶的Values控制器(多好的开刀对象)实验。
在这之前,确定好你的数据库是哪类,SqlServer请按1,MySql请按0,其他请自行查看文档。
为了方便项目统一管理,我们要好好利用appsettings,就像我们当时使用web.config一样,连接串自己根据实际情况修改。
//新加一个
"DefaultSqlConnectionString": {
"MySql": "server=127.0.0.1;userid=root;password=root;database=test;"
}
在我们Util层的AprilConfig,来获取参数。
private static string _MySqlConnectionString = string.Empty;
/// <summary>
/// MySql默认连接串
/// </summary>
public static string MySqlConnectionString
{
get
{
if (string.IsNullOrEmpty(_MySqlConnectionString))
{
_MySqlConnectionString = Configuration["DefaultSqlConnectionString:MySql"];
}
return _MySqlConnectionString;
}
}
然后我们来修改BaseService当时留的连接串信息。
创建表结构,这里说明下,不是说非要创建,毕竟SqlSugar有CodeFirst(当然也有DbFirst),需要的朋友可去文档查看,也比较简单,在程序启动的时候来判断是否有表,或者专门做个接口做初始化操作也可以,下图做用法简介,具体还是查看文档吧,毕竟还有备份啊改列名什么的。
万事具备,之前Values这个挨千刀的东风,构造函数来获取IStudentService这个接口。
public class ValuesController : ControllerBase
{
private readonly IStudentService _service;
public ValuesController(IStudentService service)
{
_service = service;
}
}
- 插入
[HttpGet]
public ActionResult<IEnumerable<string>> Get()
{
StudentEntity entity = new StudentEntity();
entity.Name = "小明";
entity.Age = 18;
entity.Number = "007";
entity.Sex = 0;
entity.Address = "大洛阳";
_service.Insert(entity);
return new string[] { "value1", "value2" };
}
- 修改
这里刚好也演示下SqlFilterEntity这个自己写的方法的用法,并且扩展了下实体的方法,方便使用。
SqlFilterEntity扩展方法
//...之前的实体对象
/// <summary>
/// 添加查询条件
/// </summary>
/// <param name="filter">条件</param>
/// <param name="relation">关系</param>
public void Append(string filter, string relation = "and")
{
if (string.IsNullOrEmpty(filter))
{
return;
}
if (Filter.Length > 0)
{
Filter += relation;
}
Filter += filter;
}
/// <summary>
/// 添加查询参数
/// </summary>
/// <param name="key">键</param>
/// <param name="value">值</param>
public void Add(string key, object value)
{
if (string.IsNullOrEmpty(key) || value == null)
{
return;
}
if (Value == null)
{
Value = new Dictionary<string, object>();
}
if (Value.ContainsKey(key))
{
Value[key] = value;
}
else
{
Value.Add(key, value);
}
}
修改测试
StudentEntity entity = null;
SqlFilterEntity filter = new SqlFilterEntity();
filter.Append($"ID=@ID");
filter.Add("@ID", 1);
entity = _service.GetEntity(filter);
if (entity != null)
{
entity.Name = "我被修改了";
_service.Update(entity);
}
- 删除
删除这个不多说,就是把修改的换个方法。
- 查看
这里直接做分页的测试,拿Values/{id}这个接口做实验。
[HttpGet("{id}")]
public ActionResult<string> Get(int id)
{
string value = string.Empty;
//value = CacheUtil.Get<string>("cachetest");
//value = SessionUtil.GetSession("test");
//value = CookieUtil.GetCookies("apirlcookietest");
int count = 0;
List<StudentEntity> lists = _service.GetPageList(id, 10, "", null, "", out count);
value = JsonConvert.SerializeObject(lists);
return value;
}
小结
这里大致上介绍了SqlSugar的用法已经一些基础的不能基础的封装,实际使用的话,肯定需要扩展完善的,但是作为教程来讲,我也不可能把全部的情况都考虑到,毕竟业务不同,没有万金油,只有不停的完善更新,业务场景多了,功能就完善了,一步一步来,一口吃不成个胖子(这个胖子不是你认识的那个胖子),不过还是感慨下这些开源的好类库,真的是方便了开发人员,为了解放程序猿的双手(yy)做出了嗨翻天的贡献,好了,回归正题,下一篇Aop的测试以及小东西。
net core Webapi基础工程搭建(六)——数据库操作_Part 2的更多相关文章
- net core Webapi基础工程搭建(六)——数据库操作_Part 1
目录 前言 SqlSugar Service层 BaseService(基类) 小结 前言 后端开发最常打交道的就是数据库了(静态网站靠边),上一篇net core Webapi基础工程搭建(五)-- ...
- net core Webapi基础工程搭建(七)——小试AOP及常规测试_Part 2
目录 前言 引入 自定义属性 测试 小结 前言 前一篇讲到了中间层的使用,可能不是那么AOP,今天主要来说下一个轻量级的AOP第三方类库AspectoCore. 简单介绍下这个类库,AspectCor ...
- net core Webapi基础工程搭建(五)——缓存机制
目录 前言 Cache Session Cookie 小结 补充 前言 作为WebApi接口工程,性能效率是必不可少的,每次的访问请求,数据库读取,业务逻辑处理都或多或少耗费时间,偶尔再来个各种花式f ...
- net core Webapi基础工程搭建(二)——创建工程
目录 前言 创建工程 工程文件概述(个人理解) 运行 小结 前言 前面介绍了开发工具及net core版本,后端工程的框架结构开发工具及环境,因为是基础工程,所以没考虑太复杂的框架,如果有架构师请勿喷 ...
- net core Webapi基础工程搭建(七)——小试AOP及常规测试_Part 1
目录 前言 拦截器 异常拦截器 测试结果 身份验证拦截器 测试 小结 补充 2019-07-31 前言 一天天不知道怎么过的,但确实挺忙,事赶事不带停那种,让我感觉跟在流水线干活一样,忙活的事差不多了 ...
- net core Webapi基础工程搭建(一)——开发工具及环境
目录 开发工具 版本 后端框架 开发工具 Visual Studio 2019,既然要折腾那就体验最新版的开发工具有什么特殊的地方,之前个人开发使用的是2017. 下载地址:https://visua ...
- net core Webapi基础工程搭建(四)——日志功能log4net
目录 前言 log4net 依然是,NuGet引用第三方类库 整合LogUtil 小结 前言 一个完整的项目工程离不开日志文件的记录,而记录文件的方法也有很多,可以自己通过Stream去实现文件的读写 ...
- net core Webapi基础工程搭建(三)——在线接口文档Swagger
目录 前言 Swagger NuGet引用第三方类库 别急,还有 没错,注释 小结 前言 前后分离的好处,就是后端埋头做业务逻辑功能,不需要过多考虑用户体验,只专注于数据.性能开发,对于前端需要的数据 ...
- 第十九节:Asp.Net Core WebApi基础总结和请求方式
一. 基础总结 1.Restful服务改造 Core下的WebApi默认也是Restful格式服务,即通过请求方式(Get,post,put,delete)来区分请求哪个方法,请求的URL中不需要写方 ...
随机推荐
- 【HDU - 3533】Escape(bfs)
Escape Descriptions: 一个人从(0,0)跑到(n,m),只有k点能量,一秒消耗一点,在图中有k个炮塔,给出炮塔的射击方向c,射击间隔t,子弹速度v,坐标x,y问这个人能不能安全到 ...
- 【Go】类似csv的数据日志组件设计
原文链接:https://blog.thinkeridea.com/201907/go/csv_like_data_logs.html 我们业务每天需要记录大量的日志数据,且这些数据十分重要,它们是公 ...
- 万字长文:ELK(V7)部署与架构分析
ELK(7版本)部署与架构分析 1.ELK的背景介绍与应用场景 在项目应用运行的过程中,往往会产生大量的日志,我们往往需要根据日志来定位分析我们的服务器项目运行情况与BUG产生位置.一般情况下直接在日 ...
- Modify column Vs change column
引言 I know, we can not rename a column using modify column syntax,but can change column syntax. My qu ...
- 史上最全IO流详解,看着一篇足矣
一:要了解IO,首先了解File类 File类里面的部分常量,方法 No. 方法或常量 类型 描述 1 public static final String pathSeparator 常量 表示路径 ...
- hive show databases 添加条件
show databases like 'test012301' ; 通配符: show databases like 'a*';
- 7kyu (难度系数kyu阶段数值越大难度越低) 数组分组及求和
几个人排成一排,分成两队.第一个人进入一队,第二个人进入第二队,第三个人进入第一队,以此类推. 给定一个正整数的数组(人的权重),返回两个整数的新数组/元组,其中第一个是第1组的总重量,第二个是第2组 ...
- Nginx服务器安全加固tips整理
公司各业务网站大多用到Nginx,花了点时间整理了一下Nginx服务器安全加固的各类tips. 默认配置文件和Nginx端口 /usr/local/nginx/conf/-Nginx配置文件目录,/u ...
- Shell基本语法---常见的条件判断
语法 [ 判断表达式 ] 文件夹或路径是否存在 -e 目标是否存在(exist) -d 是否为路径(directory) -f 是否为文件(file) [ -e text.sh ] || touch ...
- String常量池和intern方法
String s1 = "Hello"; String s2 = "Hello"; String s3 = "Hel" + "lo ...