asp.net core 使用Mysql和Dapper
序曲:学习编程最好的方式就是敲代码,没有比这个更好的方法,哪怕你看了上百G的视频,都不如你自己敲几行代码更为有效。还有要记得敲完代码然后写一篇随笔来记录一下你所学所想。
大家都知道,.netcore是微软一个具有历史意义的产品,因为终于开始跨平台了,
敲了那么多年的代码,每次都被吐槽不能跨平台,现在终于开启了跨平台的脚步了。
既然跨平台了,那么我们是不是可以使用mysql了,毕竟mysql的使用率是非常的高,
各种解决方案和优化方案都非常的多。如果你不知道什么是mysql,那么你自己去百度一下。
好了,废话太多了,我们开始来讲一讲如何在core上使用mysql。
第一步,当然是引用对应的包了
本次主要是引用两个包,分别是
MySql.Data
Dapper
引用成功之后,就开始敲代码
本讲解使用的是core控制台
当然首先你得安装mysql到你的电脑上,或者安装到centOs上面
windows安装mysql,你可以看看这位的方案:https://www.cnblogs.com/xsmile/p/7753984.html
centOS7安装mysql,你可以看看这个:https://www.cnblogs.com/Jomini/p/10749657.html
本人的mysql是安装到我的windows上的
配置你的数据库连接,这个信息最好放在配置文件中,这次是为了演示,我就放在代码中
//配置你的数据库连接信息
private static string ConnString = "server=192.168.1.2;userid=root;pwd=123456;port=3306;database=redenvelopes;SslMode=none";
server是你的mysql安装到的机器上的ip地址
userid是mysql登录用户 pwd是登录密码
port是mysql的端口,一般情况下,mysql的默认端口就是3306
database是你的数据库名称
SslMode是SSL模式,这里为none
我们在以前写sql的时候,都习惯给自己写一个helper,但是这里不用了,别人都帮你写好了,你拿去直接调用即可
MySqlHelper包含了丰富的api,各种增删改查,也基本满足你的需求了,这个和以前使用没什么区别
class Program
{
//配置你的数据库连接信息
private static string ConnString = "server=192.168.1.2;userid=root;pwd=123456;port=3306;database=redenvelopes;SslMode=none";
static void Main(string[] args)
{
DataSet dataSet= MySqlHelper.ExecuteDataset(ConnString, "select * from luckmoney "); }
}
这个虽好,但是不利于封装到实体对象中,
所以我们引入了Dapper
如果学过java的人看到这个,是不是感觉挺眼熟,java中有一个mapper
本人也学过java,所以有这个感觉。
Dapper是一款轻量级ORM工具
为什么选择Dapper
- 轻量。只有一个文件(SqlMapper.cs)。
- 速度快。Dapper的速度接近与IDataReader,比DataTable好很多
- 支持多种数据库,包括sqlite, sqlce, firebird, oracle, MySQL, PostgreSQL and SQL Server
- 可以映射一对一,一对多,多对多等多种关系。
- 性能高。通过Emit反射IDataReader的序列队列,来快速的得到和产生对象,性能不错。
当然最重要的是使用起来非常的方便。
在我们上面代码基础上,引入Dapper后,你会发现变得不一样了
这里我们先加一个实体
如下所示:
MySqlConnection被扩展了更多的方法,这些都是Dapper所带来的
using MySql.Data.MySqlClient;
using System;
using System.Data;
using Dapper; namespace MySQL_Demo
{
class Program
{
//配置你的数据库连接信息
private static string ConnString = "server=192.168.1.2;userid=root;pwd=123456;port=3306;database=redenvelopes;SslMode=none";
static void Main(string[] args)
{
MySqlConnection mySqlConnection = new MySqlConnection(ConnString);
var list = mySqlConnection.Query<luckmoney>("select * from luckmoney ", null);
foreach (var item in list)
{
Console.WriteLine(item.id);
}
}
} public class luckmoney
{
public int id
{
get; set;
} public decimal money
{
get; set;
} public string consumer
{
get; set;
} public string producer
{
get; set;
}
}
}
如果你想用参数,也很简单,如下所示:
MySqlConnection mySqlConnection = new MySqlConnection(ConnString);
var list = mySqlConnection.Query<luckmoney>("select * from luckmoney where id=@id ",new { id= });
foreach (var item in list)
{
Console.WriteLine(item.id);
}
在这里我就不讲很复杂的东西,只是简单的引导你们怎么使用mysql和Dapper,希望大家多敲一敲代码,里面还有更多东西等你们探索。
总结:现在敲代码越来越方便了,以前还要自己去敲各种helper,现在别人都给你封装好了,你自己去使用就可以,可以说什么很方便了
但是不能因此不去探索这些东西的原理,不去探索,你只是敲代码的机器,探索了,你的代码就代入了你的思想和灵魂,我以前和大家一样
每天就是各种增删改查,各种copy,几年下来,东西没学到多少,年龄大了,更不好找工作。
各位别嫌弃我废话太多,毕竟我们程序员是孤独的。
asp.net core 使用Mysql和Dapper的更多相关文章
- Visual Studio Code和Docker开发asp.net core和mysql应用
Visual Studio Code和Docker开发asp.net core和mysql应用 .net猿遇到了小鲸鱼,觉得越来越兴奋.本来.net猿只是在透过家里那田子窗看外面的世界,但是看着海峡对 ...
- ASP.NET Core 1.0 使用 Dapper 操作 MySql(包含事务)
操作 MySql 数据库使用MySql.Data程序包(MySql 开发,其他第三方可能会有些问题). project.json 代码: { "version": "1. ...
- 记一次使用Asp.Net Core WebApi 5.0+Dapper+Mysql+Redis+Docker的开发过程
#前言 我可能有三年没怎么碰C#了,目前的工作是在全职搞前端,最近有时间抽空看了一下Asp.net Core,Core版本号都到了5.0了,也越来越好用了,下面将记录一下这几天以来使用Asp.Net ...
- ASP.NET Core 实战:基于 Dapper 扩展你的数据访问方法
一.前言 在非静态页面的项目开发中,必定会涉及到对于数据库的访问,最开始呢,我们使用 Ado.Net,通过编写 SQL 帮助类帮我们实现对于数据库的快速访问,后来,ORM(Object Relatio ...
- Asp.Net Core 连接Mysql
上一篇文章里最后在VS里测试是没有问题的,但是在Windows命令行模式下会报错. 首先用dotnet restore命令的时候会出现error: 然后用dotnet run会出现警告,但是依旧会成功 ...
- docker4dotnet #3 在macOS上使用Visual Studio Code和Docker开发asp.net core和mysql应用
.net猿遇到了小鲸鱼,觉得越来越兴奋.本来.net猿只是在透过家里那田子窗看外面的世界,但是看着海峡对岸的苹果园越来越茂盛,实在不想再去做一只宅猿了.于是,.net猿决定搭上小鲸鱼的渡轮到苹果园去看 ...
- 在Asp.Net Core中集成ABP Dapper
在实际的项目中,除了集成ABP框架的EntityFrameworkCore以外,在有些特定的场景下不可避免地会使用一些SQL查询语句,一方面是由于现在的EntityFrameworkCore2.X有些 ...
- Asp.Net Core链接Mysql数据库
一.新建一个Asp.Net Core WebMVC程序 添加nuget包 Mysql.Data 二.新建一个UserContext类 下面代码中的UserInfo是我自己建的一个实体,里面有俩字段: ...
- asp.net core容器&mysql容器network互联 & docker compose方式编排启动多个容器
文章简介 asp.net core webapi容器与Mysql容器互联(network方式) docker compose方式编排启动多个容器 asp.net core webapi容器与Mysql ...
随机推荐
- ZYNQ Block Design中总线位宽的截取与合并操作
前言 在某些需求下,数据的位宽后级模块可能不需要原始位宽宽度,需要截位,而某些需求下,需要进行多个数据的合并操作. 在verilog下,截位操作可如下所示: wire [7:0] w_in; wire ...
- ElementUI使用v-if控制tab标签显示遇到的Duplicate keys detected: 'xxx'问题
今天工作遇到一个问题: 需求背景:页面中有几个tab,需要根据登录用户的权限控制tab标签的显示与隐藏 . <el-tabs @tab-click="handleClick" ...
- 大型互联网公司分布式ID方案总结
ID是数据的唯一标识,传统的做法是利用UUID和数据库的自增ID,在互联网企业中,大部分公司使用的都是Mysql,并且因为需要事务支持,所以通常会使用Innodb存储引擎,UUID太长以及无序,所以并 ...
- 特殊字符处理 java-jsp
public String dealStr(String name){ String newStr=""; if(name != null && name.leng ...
- P2774 方格取数问题 网络最大流 割
P2774 方格取数问题:https://www.luogu.org/problemnew/show/P2774 题意: 给定一个矩阵,取出不相邻的数字,使得数字的和最大. 思路: 可以把方格分成两个 ...
- 利用PIL库创建空白图像
背景 最近,想自己生成带位置坐标的文字数据集来训练文本位置探测网络. 理想情况是,给文字加盐噪声,背景不需要加噪声,所以需要创建一个空白的背景.将文字放在空白背景上,然后利用opencv加噪声. 解决 ...
- cesium中json,geojson,stk,影像切片等数据的加载
cesium中json.topojson.geojson.stk,影像切片等数据的加载 一.geojson.topojson,json数据的加载 不管是哪种json,都可以通过GeoJsonDataS ...
- Educational Codeforces Round 68 Editorial
题目链接:http://codeforces.com/contest/1194 A.Remove a Progre ...
- MPA JS CSS预处理方案
1.WebPack 添加配置文件webpack.config.js,直接在当前目录运行 webpack. var basepath = '/root/webapps/happ'; var glob = ...
- SpringBoot整合ActiveMQ,看这篇就够了
ActiveMQ是Apache提供的一个开源的消息系统,完全采用Java来实现,因此它能很好地支持JMS(Java Message Service,即Java消息服务)规范:本文将详细介绍下Activ ...