Mysql - 增删改
因为项目原因, mysql用了两年了, 但是一直都未曾去总结过. 最近也是领导让总结项目, 才想起把mysql的使用小结一下.
一、 Create
1. 单条插入, sql格式: insert into (列名) values(列值);
INSERT INTO test.tch_teacher ( Sex, BId, NO, NAME, IsDoublePosition, CreateDate )
VALUES ( 1, '', '', 'Insert', 0, NOW() );
对于自增的 Id, 是不需要写的, 数据库会自动生成, 但是如果一不小心写上去了, 只要你的Id值, 在数据库中不存在, 是可以插入进去的.
在mysql中, 就算你插入的 id 为负数, 也是可以插入成功的. 如果数据库中已存在你想插入的 id 值, 则会直接报错.
2. 多条插入, sql格式: insert into (列名) values(列值),(列值),(列值);
INSERT INTO test.tch_teacher ( Sex, BId, NO, NAME, IsDoublePosition, CreateDate )
VALUES
( 2, '', '', 'Insert', 0, NOW() ),
( 3, '', '', 'Insert', 0, NOW() ),
( 4, '', '', 'Insert', 0, NOW() );
新增多条的时候, 也可以循环调用单条插入语句去插入, 不过, 这种方式并不推荐使用, 因为, 这种方式, 消费更多性能和时间.
3. 表插入
可以新建一张临时表: tch_teacher_temp
CREATE TABLE `tch_teacher_temp` (
`Sex` smallint(6) DEFAULT NULL,
`BId` varchar(36) CHARACTER SET utf8 DEFAULT NULL,
`No` varchar(20) CHARACTER SET utf8 DEFAULT NULL,
`Name` varchar(30) CHARACTER SET utf8 DEFAULT NULL,
`IsDoublePosition` bit(1) DEFAULT NULL,
`CreateDate` datetime DEFAULT NULL,
PRIMARY KEY (`Id`)
)
这里有一个取巧的方式, 来获取建表sql
show create table tch_teacher;
然后修改一下表名,删除主键(也可不删)就可以了.
insert into tch_teacher (Sex, BId, NO, NAME, IsDoublePosition, CreateDate)
select * from tch_teacher_temp;
-- 或者
insert into tch_teacher (Sex, BId, NO, NAME, IsDoublePosition, CreateDate)
select Sex, BId, NO, NAME, IsDoublePosition, CreateDate from tch_teacher_temp;
4. 性能比较
我粗略测试了一下, 十万级和百万级的数据量, 插入1000条数据. tch_teacher表, 我建了三个索引:Sex, BId, IsDoublePosition
1). 不使用事务, 一条一条插入, 循环以下这条语句, 1000次
for (int i = ; i < ; i++)
{
var param = new { BId = Guid.NewGuid(), Name = names[ran.Next()] + names[ran.Next()] + i, IsDoublePosition = i % , CreateDate = DateTime.Now, Sex = i % , No = ran.Next(, ) };
conn.Execute(insertSql, param);
}
2). 在使用事务的情况下, 还是循环这条语句, 不同的是, 在循环结束处, 加入事务提交(这次的插入是在上次的数据量基础上, 也就是说, 这次插入前, 数据比上次多1000条)
var tran = conn.BeginTransaction();
for (int i = ; i < ; i++)
{
var param = new { BId = Guid.NewGuid(), Name = names[ran.Next()] + names[ran.Next()] + i, IsDoublePosition = i % , CreateDate = DateTime.Now, Sex = i % , No = ran.Next(, ) };
conn.Execute(insertSql, param, tran);
}
tran.Commit();
3). 拼接sql语句的情况下, 由于是"(),(),();"格式的, 所以参数我全做入sql中了, 这里参数化的方式, 不好做. (这次的插入也是在上次的数据量基础上, 也就是说, 这次插入前, 数据比上次多1000条)
StringBuilder sb = new StringBuilder("insert into tch_teacher(BId,Sex,No, Name, IsDoublePosition, CreateDate) values ", );
for (int i = ; i < ; i++)
{
sb.Append(string.Format("('{0}', {1}, '{2}', '{3}', {4}, '{5}'),",
Guid.NewGuid(),
i % ,
ran.Next(, ),
names[ran.Next()] + names[ran.Next()] + i,
i % ,
DateTime.Now.ToString("yyyy-MM-dd")));
}
sb.Remove(sb.Length - , );
conn.Execute(sb.ToString());
这种方式, 有两个不好的地方, 一个是不能参数化, 另一个是如果插入数据较多, 会导致sql语句太长, 所以并不推荐
4). 建临时表的方式, 这里我是事先吧临时表建好的, 在代码里面就没有建了
var insertSql = @"insert into tch_teacher_temp(BId,Sex,No, Name, IsDoublePosition, CreateDate) values(@BId, @Sex, @No, @Name, @IsDoublePosition, @CreateDate);";
var tran = conn.BeginTransaction();
for (int i = ; i < ; i++)
{
var param = new { BId = Guid.NewGuid(), Name = names[ran.Next()] + names[ran.Next()] + i, IsDoublePosition = i % , CreateDate = DateTime.Now, Sex = i % , No = ran.Next(, ) };
conn.Execute(insertSql, param, tran);
}
conn.Execute(@"insert into tch_teacher (Sex, BId, NO, NAME, IsDoublePosition, CreateDate) select Sex, BId, NO, NAME, IsDoublePosition, CreateDate from tch_teacher_temp;", null, tran1);
tran.Commit();
这种方式, 每次都要新建表, 删除表. 也是挺麻烦的, 这里的测试, 就没有包含新建表和删除表了
结果:
十万(ms) | 百万(ms) | |
sql拼接 | 230 | 359 |
事务提交 | 412 | 511 |
临时表 | 661 | 1424 |
一条一条 | 27606 | 36620 |
除了一条一条提交方式, 其他的在时间上, 还是能接受的, 但是推荐使用第2种, 事务提交方式, 易用, 清晰, 省事.
二、Delete
删除就相对简单多了. 删除sql的格式: delete from 表名 where 条件
删除的时候, 如果不加where条件, 就是删除整张表的数据, 相当于 where 1=1 ;
delete from tch_teacher where id=1;
这是一条最简单的语句了.
删除的时候, 对于主键的自增没有影响. 比如主键为 1,2,3
这时候删除了3, 再插入一条数据, 主键为从4开始.
如果想要让主键又从1开始的话, 需要使用truncate
truncate table tch_teacher ;
这样, 表回归初始状态.
有时候, 通过where查找后, 能得出很多条数据, 但是我只想删除其中的前几条, 那怎么办呢. 有办法
delete from tch_teacher where isDoublePosition=1 order by id limit 6;
这条语句, 就是删除 满足条件的, 前6条数据
三、Update
sql格式: update 表名 set 列=值 where 条件
update的where条件也是可以不加的, 不加的情况下, 修改的就是全部数据.
update tch_teacher set name='黑茶' where id=3;
修改的时候, 也是可以通过连表的方式, 去修改数据的.
update tch_teacher , tch_contact set tch_teacher.`Name`='红茶' where tch_teacher.Id=tch_contact.TId and tch_contact.Id=1003;
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 ...
- nodejs+express+mysql 增删改查
之前,一直使用的是nodejs+thinkjs来完成自己所需的项目需求,而对于nodejs中另外一中应用框架express却了解的少之又少,这两天就简单的了解了一下如何使用express来做一些数据库 ...
- Node+Express+node-mysql 实战于演习 全套mysql(增删改查)
最近这段时间研究Node感觉不错,自己做了一个增删改查,虽然有些简陋,但是思想是想通的,其实所有项目都是增删改查,有助于初学者快速掌握Node 首先 本实例展示的是基于Node+Express+nod ...
- mysql 增删改查最基本用法小结
目录: 1.新建数据库 2.新建数据表 3.查看表结构 4.增删改查 建立一个数据库students 建立一块数据表class1 内容包括: id 主键 自动编号 无符号位 SMALLINT类型 na ...
随机推荐
- java中的字符串相关知识整理
字符串为什么这么重要 写了多年java的开发应该对String不陌生,但是我却越发觉得它陌生.每学一门编程语言就会与字符串这个关键词打不少交道.看来它真的很重要. 字符串就是一系列的字符组合的串,如果 ...
- 阿里签名中URLEncode于C#URLEncod不同之处
问题 如上图所示,阿里云的PercentEncode 转换! 为 %21 PercentEncode 源码为: package com.aliyuncs.auth; import java.io.Un ...
- Ubuntu 14.04中Elasticsearch集群配置
Ubuntu 14.04中Elasticsearch集群配置 前言:本文可用于elasticsearch集群搭建参考.细分为elasticsearch.yml配置和系统配置 达到的目的:各台机器配置成 ...
- 有朋友问了数据库ID不连续,怎么获取上一篇和下一篇的文章?(不是所有情况都适用)
呃 (⊙o⊙)…,逆天好久没写SQL了,EF用的时间长了,SQL都不怎么熟悉了......[SQL水平比较菜,大牛勿喷] 方法很多种,说个最常见的处理 因为id是自增长的,所以一般情况下下一篇文章的I ...
- Matlab数值计算示例: 牛顿插值法、LU分解法、拉格朗日插值法、牛顿插值法
本文源于一次课题作业,部分自己写的,部分借用了网上的demo 牛顿迭代法(1) x=1:0.01:2; y=x.^3-x.^2+sin(x)-1; plot(x,y,'linewidth',2);gr ...
- Unity3D 5.3 新版AssetBundle使用方案及策略
1.概览 Unity3D 5.0版本之后的AssetBundle机制和之前的4.x版本已经发生了很大的变化,一些曾经常用的流程已经不再使用,甚至一些老的API已经被新的API所取代. 因此,本文的主要 ...
- Git小技巧 - 指令别名及使用Beyond Compare作为差异比较工具
前言 本文主要写给使用命令行来操作Git的用户,用于提高Git使用的效率.至于使用命令还是GUI(Tortoise Git或VS的Git插件)就不在此讨论了,大家根据自己的的喜好选择就好.我个人是比较 ...
- Docker与CI持续集成/CD
背景 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制 ...
- css知多少之绝对定位小记
一.position定位常见属性 对于属性position来说,属性值有static/relative/absolute/fixed/inherit以下只对绝对定位position:absolute详 ...
- git init和git init -bare区别
1 Git init 和 git init –bare 的区别 用"git init"初始化的版本库用户也可以在该目录下执行所有git方面的操作.但别的用户在将更新push上来的 ...