MySQL学习笔记

1.查看表的定义

show create table 表名称;

2.查看表中每一个字段的定义(包括校对规则)

show full columns from 表名称;

3.并行事务处理带来的问题

  • 更新丢失:T1和T2读取同一行,T1修改写入,T2再修改写入,T1的修改(更新)丢失(锁定正在读取的行可以解决)
  • 脏读:T1读完,T1修改,在提交之前,数据处于不一致状态;T2读,T1提交(修改生效),T2读的是错误数据(锁定正在读取的行可以解决)
  • 不可重复读:T1读完未提交,T2更改生效,T1再确认,T1发现两次读取的值不一样(锁定所读取的所有行可以解决)
  • 幻读:T1执行查询操作,未提交,T2插入或删除了一些数据生效,T1按相同的查询条件再次查询,T1发现两次查询结果不一致,就好像幻觉一样。(锁定表可以解决)

4.解决隔离和并发的矛盾
数据库的事务隔离越严格,并发副作用越小,但并发访问的能力下降,为了解决隔离和并发的矛盾,可以根据自己的业务需要,选择合适的隔离级别:

  • 未提交读:会出现脏读、不可重复读、幻读 ( 隔离级别最低,并发性能高 )
  • 已提交读:锁定正在读取的行,会出现不可重复读、幻读
  • 可重复读:锁定所读取的所有行,会出现幻读
  • 可序列化:锁定表,所有情况均不会发生

5.触发器三要素:

  • 事件类型:增删改(insert、delete和update);
  • 触发时间:事件类型前和后,即before和after;
    -- before:在增删改之前执行触发内容主体
    -- after:在增删改成功之后执行触发内容主体
  • 触发对象:表中的每一条记录(行),即整张表(for each row )

6.创建触发器:

delimiter $$(将命令结束符设定为$$)
create trigger 触发器名称 after/before insert/delete/update on 表名 for each row
begin
触发内容主体(每行用分号结尾);
end
$$
delimiter;(将命令结束符重新设定为;)

7.查看触发器

show triggers\G
show create trigger 触发器名称 \G

\G会将结果旋转90°,以便查看。在navicat中使用 \G会导致语法错误

select * from information_schema.triggers where trigger_name='触发器名称'\G

8.触发器记录

  • OLD:旧记录,即当前记录的状态(触发器未触发之前的记录),插入时没有OLD;
  • NEW:新记录,即假设操作发生之后记录的状态,删除时没有NEW。
    当在触发内容主体中需要用到(触发器创建的)表中某个字段的新/旧记录时
OLD/NEW.字段名

9.分支结构

if 条件判断 then
    -- 满足条件时,要执行的代码
else -- 可以没有 else 语句
    -- 不满足条件时,要执行的代码
end if;

9.循环结构

循环名称: while 条件判断 do
    -- 满足条件时要执行的代码
    -- 变更循环条件
    iterate/leave 循环名称; -- 控制循环语句(继续循环/结束循环)
end while;

10.主键冲突的两种解决方法
在一个定义了主键的表中插入新纪录,如果主键对应的值已存在,就会插入失败

1062 - Duplicate entry '2' for key 'PRIMARY'

这就是主键冲突,如何对主键已经存在的记录进行更改呢?

  • 第一种方法:更新
insert into  表名[(字段列表:包含主键)]  values (值列表) 
on duplicate key 
update 字段 = 新值;
  • 第二种方法:替换(更简便)
replace into 表名[(字段列表:包含主键)]  values (值列表);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容