.net Core+Dapper MySQL增删改查
新建一个用户表,以该有为例
1.Model层
public class TuiUsers
{
public int id { get; set; }
public string userName { get; set; }
public string userPass { get; set; }
public int userType { get; set; }
public string company { get; set; }
public string detail { get; set; } public DateTime create_time { get; set; }
public DateTime edit_time { get; set; } public int pid { get; set; } public string alipayUrl { get; set; }
public string taobaoUrl { get; set; }
public string linkMan { get; set; } public string contactInfo { get; set; }
public decimal priceRatio { get; set; }
public int stateFlag { get; set; } }
2.Dal层
通用连接
internal class ConnectionFactory
{ public static DbConnection GetOpenConnection(string connstr)
{
var connection = new MySql.Data.MySqlClient.MySqlConnection(connstr);
connection.Open();
return connection; } }
数据层
public partial class TuiUsersDal
{
public string ConnStr { set; get; } public List<Entities.TuiUsers> GetListUser(string strWhere)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("select * ");
strSql.Append(" FROM `tuiusers` ");
if (strWhere.Trim() != "")
{
strSql.Append(" where " + strWhere);
}
List<Entities.TuiUsers> list = new List<Entities.TuiUsers>();
using (var connection = ConnectionFactory.GetOpenConnection(ConnStr))
{
list = connection.Query<Entities.TuiUsers>(strSql.ToString()).ToList(); }
return list;
} /// <summary>
/// 增加一条数据
/// </summary>
public bool Add(Entities.TuiUsers model)
{
DynamicParameters Parameters = new DynamicParameters();
int cnt = ;
string sQuery = "INSERT INTO tuiusers (userName,userPass,userType,company,detail,create_time,edit_time,pid,alipayUrl,taobaoUrl,linkMan,contactInfo,priceRatio)"
+ " VALUES(@userName,@userPass,@userType,@company,@detail,@create_time,@edit_time,@pid,@alipayUrl,@taobaoUrl,@linkMan,@contactInfo,@priceRatio)";
Parameters.Add("alipayUrl", model.alipayUrl);
Parameters.Add("company", model.company);
Parameters.Add("contactInfo", model.contactInfo);
Parameters.Add("create_time", model.create_time);
Parameters.Add("detail", model.detail);
Parameters.Add("edit_time", model.edit_time);
Parameters.Add("linkMan", model.linkMan);
Parameters.Add("pid", model.pid);
Parameters.Add("priceRatio", model.priceRatio);
Parameters.Add("stateFlag", model.stateFlag);
Parameters.Add("taobaoUrl", model.taobaoUrl);
Parameters.Add("userName", model.userName);
Parameters.Add("userPass", model.userPass);
Parameters.Add("userType", model.userType);
using (var connection = ConnectionFactory.GetOpenConnection(ConnStr))
{ cnt = connection.Execute(sQuery, Parameters);
} if (cnt > )
{
return true;
}
else
{
return false;
}
} /// <summary>
/// 根据ID删除一条数据
/// </summary>
public bool Delete(int id)
{
DynamicParameters Parameters = new DynamicParameters();
int cnt = ;
string sQuery = "Delete FROM tuiusers " + "WHERE Id=@Id";
Parameters.Add("Id", id);
using (var connection = ConnectionFactory.GetOpenConnection(ConnStr))
{
cnt = connection.Execute(sQuery, Parameters);
}
if (cnt > )
{
return true;
}
else
{
return false;
}
} /// <summary>
/// 更新一条数据
/// </summary>
public bool Update(Entities.TuiUsers model)
{
DynamicParameters Parameters = new DynamicParameters();
string sQuery = "UPDATE tuiusers SET userPass=@userPass,userType=@userType,company=@company,detail=@detail,edit_time=@edit_time,pid=@pid,alipayUrl=@alipayUrl,taobaoUrl=@taobaoUrl,linkMan=@linkMan,contactInfo=@contactInfo,priceRatio=@priceRatio where userName=@userName";
Parameters.Add("alipayUrl", model.alipayUrl);
Parameters.Add("company", model.company);
Parameters.Add("contactInfo", model.contactInfo);
Parameters.Add("create_time", model.create_time);
Parameters.Add("detail", model.detail);
Parameters.Add("edit_time", model.edit_time);
Parameters.Add("linkMan", model.linkMan);
Parameters.Add("pid", model.pid);
Parameters.Add("priceRatio", model.priceRatio);
Parameters.Add("stateFlag", model.stateFlag);
Parameters.Add("taobaoUrl", model.taobaoUrl);
Parameters.Add("userName", model.userName);
Parameters.Add("userPass", model.userPass);
Parameters.Add("userType", model.userType); int cnt = ;
using (var connection = ConnectionFactory.GetOpenConnection(ConnStr))
{
cnt = connection.Execute(sQuery, Parameters);
}
if (cnt > )
{
return true;
}
else
{
return false;
}
} /// <summary>
/// 根据ID获取实体对象
/// </summary>
public Entities.TuiUsers GetModel(int id)
{
DynamicParameters Parameters = new DynamicParameters();
string sQuery = "SELECT * FROM tuiusers " + "WHERE id = @id";
Parameters.Add("id", id);
using (var connection = ConnectionFactory.GetOpenConnection(ConnStr))
{
return connection.Query<Entities.TuiUsers>(sQuery, Parameters).FirstOrDefault();
}
} /// <summary>
/// 根据userName获取实体对象
/// </summary>
public Entities.TuiUsers GetModelByUserName(string userName)
{
DynamicParameters Parameters = new DynamicParameters();
string sQuery = "SELECT * FROM tuiusers " + "WHERE userName = @userName";
Parameters.Add("userName", userName); using (var connection = ConnectionFactory.GetOpenConnection(ConnStr))
{ return connection.Query<Entities.TuiUsers>(sQuery, Parameters).FirstOrDefault();
}
} /// <summary>分页获取数据列表
///
/// </summary>
public List<Entities.TuiUsers> GetListArray(string fileds, string orderstr, int PageSize, int PageIndex, string strWhere)
{ string cond = string.IsNullOrEmpty(strWhere) ? "" : string.Format(" where {0}", strWhere); string sql = string.Format("select {0} from `tuiusers` {1} order by {2} limit {3},{4}", fileds, cond, orderstr, (PageIndex - ) * PageSize, PageSize); List<Entities.TuiUsers> list = new List<Entities.TuiUsers>();
using (var connection = ConnectionFactory.GetOpenConnection(ConnStr))
{
list = connection.Query<Entities.TuiUsers>(sql).ToList(); }
return list;
} /// <summary>计算记录数
///
/// </summary>
/// <param name="p"></param>
/// <returns></returns>
public int CalcCount(string where)
{
string sql = "select count(1) from `tuiusers`";
if (!string.IsNullOrEmpty(where))
{
sql += " where " + where;
}
using (var connection = ConnectionFactory.GetOpenConnection(ConnStr))
{
int i = connection.QuerySingle<int>(sql);
return i; }
} }
3.Startup注入
public Startup(IConfiguration configuration)
{
Configuration = configuration;
} public IConfiguration Configuration { get; } // This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{
//取出appsetting.json中的数据库连接字符串
string connStr = Configuration.GetSection("ConnStr").Value; //注入
services.AddSingleton<DAL.UsersDAL>(new DAL.UsersDAL() { ConnStr = connStr });
services.AddSingleton<DAL.TuiUsersDal>(new DAL.TuiUsersDal() { ConnStr = connStr }); //解决中文被编码
services.AddSingleton(HtmlEncoder.Create(UnicodeRanges.All)); services.Configure<CookiePolicyOptions>(options =>
{
// This lambda determines whether user consent for non-essential cookies is needed for a given request.
options.CheckConsentNeeded = context => true;
options.MinimumSameSitePolicy = SameSiteMode.None;
}); //开启授权认证相关模块(中间件)
services.AddAuthentication(
options =>
{
options.DefaultChallengeScheme = CookieAuthenticationDefaults.AuthenticationScheme;
options.DefaultAuthenticateScheme = CookieAuthenticationDefaults.AuthenticationScheme;
})
.AddCookie(options =>
{
options.LoginPath = "/Account/";
options.Cookie.HttpOnly = true;
});
services.AddTransient<HttpContextAccessor>();
services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1); }
4.配置文件
{
"ConnStr": "server=localhost;database=phone_card;uid=root;pwd=123456;charset=utf8;SslMode=None",
"Logging": {
"LogLevel": {
"Default": "Warning"
}
},
"AllowedHosts": "*"
}
.net Core+Dapper MySQL增删改查的更多相关文章
- MySQL—增删改查,分组,连表,limit,union,alter,排序,去重
MySQL增删改查 在表格的增删改查中,查的内容是最多的,包括group by ,join,limit,union,alter,排序都是服务于查的 #sql语句数据行操作补充 #增加: #insert ...
- PHP MySql增删改查
mysql_connect()连接数据库 mysql_select_db选择数据库 mysql_fetch_assoc()获取结果集 mysql_query()执行sql语句 实例如下: <?p ...
- mysql增删改查练习
Mysql增删改查sql语句练习 关于数据库的一些操作: 进入mysql 命令行: mysql -uroot –p 查看所有数据库: show databases; 创建数据库: create dat ...
- Django学习之mysql增删改查
上节介绍了如何使用命令行操作mysql增删改查,现在介绍如何使用python管理mysql 使用pip 下载完mysql后,mysql会以pymysql模块的形式存储在pycharm的包文件里.我们通 ...
- mysql增删改查相关操作
mysql增删改查相关操作 以前用mysql用的少,对于数据库相关的操作不熟悉,现在开始要接触数据库了,记录一下相关的基础操作吧. 1.数据库的授权操作 # mysql -u root -p Ente ...
- 基于gin的golang web开发:mysql增删改查
Go语言访问mysql数据库需要用到标准库database/sql和mysql的驱动.标准库的Api使用比较繁琐这里再引入另一个库github.com/jmoiron/sqlx. go get git ...
- MySQL增删改查的常用语句汇总
MySQL增删改查的常用语句汇总 以下是总结的mysql的常用语句,欢迎指正和补充~ 一.创建库,删除库,使用库 1.创建数据库:create database 库名; 2.删除数据库:drop da ...
- 使用轻量级ORM Dapper进行增删改查
项目背景 前一段时间,开始做一个项目,在考虑数据访问层是考虑技术选型,考虑过原始的ADO.NET.微软的EF.NH等.再跟经理讨论后,经理强调不要用Ef,NH做ORM,后期的sql优化不好做,公司 ...
- Dapper进行增删改查 z
http://www.cnblogs.com/huangkaiyan10/p/4640548.html 项目背景 前一段时间,开始做一个项目,在考虑数据访问层是考虑技术选型,考虑过原始的ADO.NET ...
随机推荐
- Docke--Dockerfile实践
Dockerfile 实践 nginx镜像构建 先查看下本地的镜像,选取官网的centos作为base image: [root@server ~]# docker images REPOSITORY ...
- Number和toString中的坑
在之前的一篇文章 JavaScript中的大数相加 中,在做大数相加时, 突然想到 数字.toString方法 会报错,但是作为函数参数传进来,直接调用 toString 方法却不会报错 上网搜了看看 ...
- JavaEESpringMVC基础整理
1.什么是 SpringMVC ? 在介绍什么是 SpringMVC 之前,我们先看看 Spring 的基本架构.如下图: 我们可以看到,在 Spring 的基本架构中,红色圈起来的 Spring W ...
- js重点--匿名函数
推荐博客:https://www.cnblogs.com/pssp/p/5216668.html 函数是必须要有函数名的,不然没有办法找到它,使用它. 如果没有名字必须要有一个依附体,如:将这个匿名函 ...
- mix-blend-mode
mix-blend-mode是一个css3新增的混合color与背景元素颜色的样式,同一个元素的两个颜色不影响. mix-blend-mode: normal; //正常mix-bl ...
- linux mint18 cinnamon 64bit 安装 docker
参考官方文档:https://docs.docker.com/engine/installation/linux/ubuntu/ 1. 安装一些使 apt 可以使用 https 的源 sudo apt ...
- 小程序 <web-view></web-view> 中使用 form 表单提交
在最近的小程序项目中,使用到了 <web-view></web-view> 内嵌 H5 页面,在 H5 中需要使用 form 表单提交数据. H5 使用的技术框架是 vue+v ...
- Luogu P2158 仪仗队 题解报告
题目传送门 [题目大意] 给定一个n×n的点方阵,求站在左下角的点能看到的点数 注意同一条直线上只能看到一个点 [思路分析] 因为是一个方阵,所以可以对称地算,那么对于半个方阵,这里假设是左上的半个方 ...
- JAVA的抽象类和接口
抽象类 在面向对象的概念中,所有的对象都是通过类来描述的,但是反过来,并不是所有的类都是用来描述对象的,如果一个类中没有包含足够的信息来描绘一个具体的对象,这样的类就是抽象类. 抽象类除了不能实例化对 ...
- 有关mysql索引
1.首先我们需要明确一下什么是索引以及为什么要使用索引: 索引在MySQL中也叫做“键”,是存储引擎用于快速找到记录的一种数据结构.在生产环境中,对于数据库我们最常进行的是查询的操作,而当我们的数据非 ...