首先建立.net Core API - empty 这个就不说了

然后创建新的Controller

记得添加路由

[Route("api/Users")]

然后在Nuget Packages安装 所需安装包

这里是用mysql所以下载如下的mysqlSugarCore

(切记不要忘记安装Mysql.Data)

创建实例化class文件DbContext.cs

用于连接数据库,初始化

private DbContext()
{
}
public static string ConnectionString { get; set; } public static SqlSugarClient GetInstance()
{
var db = new SqlSugarClient(ConnectionString);
return db;
}

当然记得引用MySqlSugar的库

然后在appsetting.json中创建连接字符串

点击Startup.cs在ConfigureServices函数中:

public void ConfigureServices(IServiceCollection services)
{
services.AddMvc();
DbContext.ConnectionString = Configuration.GetConnectionString("DefaultConnection");
}

然后创建model层这里我根据数据库中的字段来创建

Ok接下来前期的工作完成了 ,利用sqlSugar进行基本的增删改查操作

Select

创建select接口

[HttpPost("select")]
public string Select(Users user)
{
using (var db = DbContext.GetInstance()) {
//查询所有数据的前五条并转化为Json格式
var top5 = db.Queryable<Users>().OrderBy(it => it.username).ToJson();
//简单的条件查询,查询表中所有女生的名字
var girl = db.Queryable<Users>().Where(it =>it.sex ==).Select("name").ToJson();
return girl;
}
}

点击运行后 用postman进行调试可以看到从数据库中取出的前5条数据以JSon的格式返回或者表中女生的名字

 Insert

接下来尝试用sqlsugar实现增加的操作

 [HttpPost("add")]

        public string Register(Users user)

        {

            //这里直接不加判断就增加一条学生数据

            using (var db = DbContext.GetInstance())

            {

                var status = db.Insert(user);

                //查询刚插入的sex是否有值

                var sex = db.Queryable<Users>().Single(it => it.userid == status.ObjToInt()).sex;

                return "status:"+status.ToString() + ",sex:" + sex;

            }

        }

结果

发现数据库汇总的确多了一条数据插入成功

顺便来研究一下这个db.Insert()的返回值到底是什么东西

我换了一组值进行再次post

可以发现status从7 变成了8  我观察数据库发现这就是我的主键自增字段id的值(话说为什么就不是bool值呢)

Delete

然后来进行删除操作

 [HttpPost("delete")]
public bool RemoveUser(Users user)
{ using (var db = DbContext.GetInstance())
{
//删除根据主键
// db.Delete<Users, int>(10); //主键批量删除
//db.Delete<Users, string>(new string[] { "100", "101", "102" }); //假删除
//db.FalseDelete<school>("is_del", 100);
//等同于 update school set is_del=1 where id in(100)
//db.FalseDelete<school>("is_del", it=>it.id==100); //同时满足条件删除
bool status = db.Delete(new Users() { username = "issa2018",password = ""}); return status;
}
}

运行postman后发现返回false  我去 难道不是我想的这样??

然后我改变代码

bool status = db.Delete(new Users() { userid = });

这样就返回为true了 所以这个方法只能用于主键为参数!!!

最无语的就是我将代码改成如下(密码是错误的)以为他要同时满足条件才能删除

bool status = db.Delete(new Users() { userid =,password = ""});

但返回结果却是true(也就是仍然删除了userid为7的列)

最后发现满足多条件删除得这么来,感觉稍微有点麻烦啊

bool status = db.Delete<Users>("username=@username and password=@password", new { username = user.username,password = user.password});

那我还不如这样

bool status = db.Delete<Users>("username='"+user.username+"' and password='"+user.password+"'");

Update

先看下如何用sqlsuagr怎么修改吧

[HttpPost("update")]

        public bool EditInfo(Users user)

        {

            using (var db = DbContext.GetInstance())

            {

                //支持字典更新,适合动态权限

                //var dic = new Dictionary<string, string>();

                //dic.Add("name", "第十三条");

                //dic.Add("areaId", "1");

                //db.Update<Users, int>(dic, 13);

                //这个更新会把除了更新的东西以外的全部值都为空赋进去因为是吧整个user带进去了

                //var updateStatus = db.Update<Users>(new Users { name = user.name, remark = user.remark }, it => it.username == user.username & it.password == user.password);

                //更新name和remark的值

                var updateStatus = db.Update<Users>(new { name = user.name, remark = user.remark }, it => it.username == user.username & it.password == user.password);

                return updateStatus;

            }

        }

Postman传递数据更新成功

下一次会整理更多有用的sqlsugar的功能

.net core +mysqlSugar(最为简单的增删改查)的更多相关文章

  1. BitAdminCore框架应用篇:(二)创建一个简单的增删改查模块

    NET Core应用框架之BitAdminCore框架应用篇系列 框架演示:http://bit.bitdao.cn 框架源码:https://github.com/chenyinxin/cookie ...

  2. Java web 简单的增删改查程序(超详细)

    就是简单的对数据进行增删改查.代码如下: 1.bean层:用来封装属性及其get set方法 toString方法,有参构造方法,无参构造方法等. public class Bean { privat ...

  3. salesforce 零基础学习(五十一)使用 Salesforce.com SOAP API 实现用户登录以及简单的增删改查(JAVA访问salesforce)

    此篇请参看:https://resources.docs.salesforce.com/202/latest/en-us/sfdc/pdf/salesforce_developer_environme ...

  4. MyBatis学习--简单的增删改查

    jdbc程序 在学习MyBatis的时候先简单了解下JDBC编程的方式,我们以一个简单的查询为例,使用JDBC编程,如下: Public static void main(String[] args) ...

  5. 通过JDBC进行简单的增删改查

    通过JDBC进行简单的增删改查(以MySQL为例) 目录 前言:什么是JDBC 一.准备工作(一):MySQL安装配置和基础学习 二.准备工作(二):下载数据库对应的jar包并导入 三.JDBC基本操 ...

  6. MyBatis简单的增删改查以及简单的分页查询实现

    MyBatis简单的增删改查以及简单的分页查询实现 <? xml version="1.0" encoding="UTF-8"? > <!DO ...

  7. 初试KONCKOUT+WEBAPI简单实现增删改查

    初试KONCKOUT+WEBAPI简单实现增删改查 前言 konckout.js本人也是刚刚接触,也是初学,本文的目的是使用ko和asp.net mvc4 webapi来实现一个简单增删改查操作.Kn ...

  8. MVC3.0+knockout.js+Ajax 实现简单的增删改查

    MVC3.0+knockout.js+Ajax 实现简单的增删改查 自从到北京入职以来就再也没有接触MVC,很多都已经淡忘了,最近一直在看knockout.js 和webAPI,本来打算采用MVC+k ...

  9. SpringMVC之简单的增删改查示例(SSM整合)

    本篇文章主要介绍了SpringMVC之简单的增删改查示例(SSM整合),这个例子是基于SpringMVC+Spring+Mybatis实现的.有兴趣的可以了解一下. 虽然已经在做关于SpringMVC ...

随机推荐

  1. Flask02 路由的书写、蓝图、利用蓝图实现url前缀、利用蓝图实现子域名、访问静态文件

    1 书写路由的两种方法 1.1 利用Flask实例对象的 add_url_rule 方法实现 该方法有一个必填参数,两个默认参数 · rule : 请求路径的规则 endpoint : 端点,默认值是 ...

  2. HBase表数据分页处理

    HBase表数据分页处理 HBase是Hadoop大数据生态技术圈中的一项关键技术,是一种用于分布式存储大数据的列式数据库,关于HBase更加详细的介绍和技术细节,朋友们可以在网络上进行搜寻,笔者本人 ...

  3. CSS概念 - 可视化格式模型(一) 盒模型与外边距叠加

    可以参考<精通CSS 高级WEB标准解决方案>第三章. 可视化格式模型 可视化格式模型要掌握的3个最重要的CSS概念是 浮动.定位.盒模型. 这些概念控制在页面上安排和显示元素的方式, 形 ...

  4. Cocos creator之javascript闭包

    .什么是闭包? 闭包,官方对闭包的解释是:一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分.闭包的特点: 1. 作为一个函数变量的一个引用,当函数返回 ...

  5. Bootstrap栅格学习

    参考:https://segmentfault.com/a/1190000000743553 节选翻译自The Subtle Magic Behind Why the Bootstrap 3 Grid ...

  6. 关于.net Core项目发布在Linux上的填坑

    本文主要记录.net Core项目发布在Linux服务器上面所遇到的问题,防止遗忘是 1.在发布文件中执行 dotnet xxxxxx.dll的时候提示如下错误: An assembly specif ...

  7. Boost Python官方样例(二)

    返回值 使用return_by_value有点像C++ 11的auto关键字,可以让模板自适应返回值类型(返回值类型必须是要拷贝到新的python对象的任意引用或值类型),可以使用return_by_ ...

  8. BZOJ 1012【线段树】

    题意: Q L 询问数列最后 L 个数中最大的数. A n 将 n + t ( t_init = 0 ), 然后插到最后去. 思路: 感觉动态地插入,很有问题. 数组地长度会时常变化,但是可以先预处理 ...

  9. NSOperation的使用

    <iOS多线程编程之NSThread的使用> 介绍三种多线程编程和NSThread的使用,这篇介绍NSOperation的使用. 使用 NSOperation的方式有两种, 一种是用定义好 ...

  10. CentOS 6.6 x64安装TensorFlow

    CentOS 6.6 x64安装TensorFlow升级Python到2.7(系统自带Python版本为2.6) // 安装编译工具 $ yum -y install gcc automake aut ...