必备知识
MySQL的增删改查
# 增
insert Course values (1,'语文课')
# 删
delete from Course where c_id=1
# 改
update Course set name='音乐课' where c_id=1
#多表更新
update mmpp mp, mm m set mp.name = m.name where mp.id=m.id and mp.name=''
# 查
select * from Course
MySQL的存储过程
# 最简单的存储过程
create procedure test ()
begin
select '许嵩';
end
# 调用存储过程
call test();
# 删除存储过程
drop procedure test;
扩展知识
使用命令框登录MySql
mysql -u root - p
显示目前所有的数据库
show databases;
显示创建的数据库的编码格式
show create database shuyunquan;
引用数据库
use shuyunquan
查看当前引用的数据库
select database();
创建表
create table userInfo(
username varchar(20),
userage int
)
显示当前引用的数据库的所有表
show tables;
显示指定数据库的所有的表
show tables from mysql;
显示表里面的所有列名
show columns from user;
向表中插入一条数据
insert user values(1,'许嵩',32,'男');
向表中添加新列
alter table user add telphone int not null first;
删除某列
alter table user drop telphone;
只查询表中的若干条记录,limit加数字(SQL Server是top)
select * from user limit 2;
创建一个无参的存储过程
create procedure getVersion()
select version();
调用这个无参的存储过程,无参的加不加()都可以
call getVersion();
创建一个有参数的存储过程,这里需要讲一下,参数分为in和out两种,in是输入的参数,out是作为返回的参数,变量。下面这个存储过程就是,删除某个id的用户,返回当前用户的总个数,unsigned是非负数的意思
create procedure removeuserById(in id int unsigned,out counts int unsigned)
begin
delete from user where id=id;
select count(*) from user into counts;
end
//
调用的时候
call removeuserById (1,@count);
select @count;
移除存储过程
drop procedure removeuserById;
MySql的存储引擎,所谓的存储引擎就是把数据存储到内存或者文件中采用到技术和方式,有以下几种
- MyISAM
- InnoDB
- Memory
- CSV
- Archive
MySql并发操作
什么是并发操作呢?例如两个用户同时访问我的表,一个删除id为1的数据,一个访问id为1的数据,这就叫做并发,这样显然是会出错的,解决办法是锁。
锁机制
锁分为两种
- 共享锁(读锁):同一时间段内,多个用户可以读取同一条数据
- 排他锁(写锁):在任何时候,只能有一个用户写入资源,当进行写锁的时候会阻塞其他用户的读锁或写锁操作
锁颗粒
表锁,是一种开销最小的锁策略
行锁,是一种开销最大的锁策略
注意事项
插入必须写name,多条insert必须加分号
Mysql插入信息的时候,必须写name,不写字段name的话插入不了数据,主键还要插数据?
INSERT MemoryDocument (`MemoryCategoryId`, `Name`, `Description`, `Url`, `ApproveStatus`, `CreateManagerId`, `CreateTime`, `UpdateManagerId`, `UpdateTime`) VALUES(1,'文档9','描述内存信息描述内存信息描述内存信息描述内存信息描述内存信息描述内存信息描述内存信息描述内存信息','asd',1,1,'2019/10/15',1,'2019/10/19');
还要,如果我想插入多条数据,必须每一条数据后面加上一个分号 ???这是啥操作
INSERT MemoryDocument (`MemoryCategoryId`, `Name`, `Description`, `Url`, `ApproveStatus`, `CreateManagerId`, `CreateTime`, `UpdateManagerId`, `UpdateTime`) VALUES(1,'文档9','描述内存信息描述内存信息描述内存信息描述内存信息描述内存信息描述内存信息描述内存信息描述内存信息','asd',1,1,'2019/10/15',1,'2019/10/19');
INSERT MemoryDocument (`MemoryCategoryId`, `Name`, `Description`, `Url`, `ApproveStatus`, `CreateManagerId`, `CreateTime`, `UpdateManagerId`, `UpdateTime`) VALUES(1,'文档10','描述内存信息描述内存信息描述内存信息描述内存信息描述内存信息描述内存信息描述内存信息描述内存信息','asd',1,1,'2019/10/15',1,'2019/10/20');
不加分号的话无法执行多条insert.......
拼接字符串不能使用+,使用concat方法
我的mysql语句是这样的
UPDATE MemoryCategory set Remark=Remark+'test';
这样是错误的,因为mysql拼接字符串使用的不是+,而是 concat ,报的错误:截断了错误的DOUBLE值
正确的写法如下
UPDATE MemoryCategory set Remark=CONCAT(Remark,'test');
分组之后获取每组的前30条数据
这个写法我看不懂
select * from (select MemoryParameterName, MemoryParameterValue, count(MemoryParameterValue) as num from MemoryParameter where MemoryCategoryId=1 group by MemoryParameterName, MemoryParameterValue) as t
where (
select count(*)
from (select MemoryParameterName, MemoryParameterValue, count(MemoryParameterValue) as num from MemoryParameter where MemoryCategoryId=1 group by MemoryParameterName, MemoryParameterValue) as tt
where tt.MemoryParameterName = t.MemoryParameterName
and tt.num > t.num
) < 30
order by MemoryParameterName,num desc
字段去除最后一个字符
select name, left(name,length(name)-1) from Vae.Student where namelike '%-'
Mysql删除delete in 超级慢
我的MySQL语句是这样的
delete from VaeDB.Person where Id in (
SELECT id
FROM VaeDB.Person
WHERE status = 0
);
因为数据量比较大,结果你猜咋滴,执行了几十分钟还没有结果.........
原因就是因为我delete in里面的查询是直接查询的原表,我写的是select ... from VaeDB.person,这样不好,特别慢,可以写一个临时表,把数据全部读取到内存里面,这样就快了
delete from VaeDB.Person where Id in (
select id from(
SELECT id
FROM VaeDB.Person
WHERE status = 0
) t
);
速度从几十分钟执行不完到现在10s执行完成,看来我的数据库能力急需突破菜鸟级别