新建一个用户表,以该有为例

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增删改查的更多相关文章

  1. MySQL—增删改查,分组,连表,limit,union,alter,排序,去重

    MySQL增删改查 在表格的增删改查中,查的内容是最多的,包括group by ,join,limit,union,alter,排序都是服务于查的 #sql语句数据行操作补充 #增加: #insert ...

  2. PHP MySql增删改查

    mysql_connect()连接数据库 mysql_select_db选择数据库 mysql_fetch_assoc()获取结果集 mysql_query()执行sql语句 实例如下: <?p ...

  3. mysql增删改查练习

    Mysql增删改查sql语句练习 关于数据库的一些操作: 进入mysql 命令行: mysql -uroot –p 查看所有数据库: show databases; 创建数据库: create dat ...

  4. Django学习之mysql增删改查

    上节介绍了如何使用命令行操作mysql增删改查,现在介绍如何使用python管理mysql 使用pip 下载完mysql后,mysql会以pymysql模块的形式存储在pycharm的包文件里.我们通 ...

  5. mysql增删改查相关操作

    mysql增删改查相关操作 以前用mysql用的少,对于数据库相关的操作不熟悉,现在开始要接触数据库了,记录一下相关的基础操作吧. 1.数据库的授权操作 # mysql -u root -p Ente ...

  6. 基于gin的golang web开发:mysql增删改查

    Go语言访问mysql数据库需要用到标准库database/sql和mysql的驱动.标准库的Api使用比较繁琐这里再引入另一个库github.com/jmoiron/sqlx. go get git ...

  7. MySQL增删改查的常用语句汇总

    MySQL增删改查的常用语句汇总 以下是总结的mysql的常用语句,欢迎指正和补充~ 一.创建库,删除库,使用库 1.创建数据库:create database 库名; 2.删除数据库:drop da ...

  8. 使用轻量级ORM Dapper进行增删改查

      项目背景 前一段时间,开始做一个项目,在考虑数据访问层是考虑技术选型,考虑过原始的ADO.NET.微软的EF.NH等.再跟经理讨论后,经理强调不要用Ef,NH做ORM,后期的sql优化不好做,公司 ...

  9. Dapper进行增删改查 z

    http://www.cnblogs.com/huangkaiyan10/p/4640548.html 项目背景 前一段时间,开始做一个项目,在考虑数据访问层是考虑技术选型,考虑过原始的ADO.NET ...

随机推荐

  1. luogu4055 游戏 (二分图博弈)

    考虑对非障碍的点黑白染色然后做二分图最大匹配,那么有结论,先手必胜当且仅当不是完美匹配,而且可以放的点是那些可以不匹配的点 从非匹配点开始走,后手只能走到匹配点,于是先手就可以走匹配边.由于不能走走过 ...

  2. CC++语法::数组名退化(array decaying)

    参考: CSDN::C/C++中数组名退化为指针的情况 stackoverflow::What is array decaying? 起因 笔者在写memset的时候总想偷一点懒(因为我们一般都是为了 ...

  3. 【踩坑】利用fastjson反序列化需要默认构造函数

    利用 fastjson等 反序列化时需要注意,他可能会用到 默认的构造函数,如果没有默认构造函数,某些场景下可能会出现 反序列化熟悉为空的情况,如下图所示:

  4. Java基础--异常处理

    1.异常的传统处理方式 缺点: [1] 通过判断影响执行效率. [2] 判断逻辑和业务逻辑交织在一起,可维护性很差. public class Test01 { public static void ...

  5. 数据结构与算法之美学习笔记:B+树(第48讲)

    一.解决问题的前提是定义清楚问题 通过对一些模糊需求进行假设,来限定要解决问题的范围 根据某个值查找数据,比如 select * from use where id=1234: 根据区间值来查询某些数 ...

  6. Mongodb分片集群技术+用户验证

    随着数据量持续增多,后续迟早会出现一台机器硬件瓶颈问题的.而mongodb主打的就是海量数据架构,“分片”就用这个来解决这个问题. 从图中可以看到有四个组件:mongos.config server. ...

  7. IIS 常用命令

    Ø  简介 本文主要介绍 IIS 常用的命令,主要包含以下内容: 1.   IIS  重启方法 2.   站点重启方法 3.   应用程序池重启方法 1.   IIS 重启方法 1)   重启 IIS ...

  8. System系统类

    System系统类 : 主要的作用是用于获取系统的一个参数. System类需要掌握的方法: arraycopy(Object src, int srcPos, Object dest, int de ...

  9. 五十七、linux 编程——UDP 编程 域名解析

    57.1 介绍 57.1.1 域名解析 57.1.2 域名解析函数 gethostent 可以获取多组,gethostbyname 只可以获取一组 /etc/hosts 文件设置了域名和 IP 的绑定 ...

  10. python3 练手实例6 做一个简单日历

    import calendar year = int(input('请输入要查询的年份:')) month = int (input('请输入要查询的月数:')) print (calendar.mo ...