SQL菜鸟学习札记(二)
五月份一直在写SQL,之后写了一个期末大作业的项目,现在才有时间把之前遇到的各种奇怪的问题整理出来。下一部分札记应该是大作业中使用到的SQL的整理。
一.UPDATE SET语句后面可以并列赋值。
之前一直用的两段SQL脚本来分别赋值,效率很低,整合到一个SET语句之后效率翻倍了。(这个很基础)


1 use msi2017;
2 set sql_safe_updates = 0;
3 update finallistnum_result inner join finallistname_num
4 on finallistnum_result.raceNum = finallistname_num.raceNum
5 set finallistnum_result.TeamA = finallistname_num.TeamA ,
6 finallistnum_result.TeamB = finallistname_num.TeamB;
二.UPDATE语句的并列问题
可以理解为,每个UPDATE语句都相互独立,可以在同一SQL脚本中并列,但不可以共用同一个UPDATE语句头。

use msi2017;
update finallistnum_result set finallistnum_result.raceResult_TeamB_G1 = 'WIN'
where finallistnum_result.raceResult_TeamA_G1 = 'LOSE';
update finallistnum_result set finallistnum_result.raceResult_TeamB_G1 = 'LOSE'
where finallistnum_result.raceResult_TeamA_G1 = 'WIN';
三.又是之前遇到的safe update mode(安全更新模式)的设置问题,错误代码1175。
不用慌,下面的SQL脚本已经写出了解决方法(之前也有数次用到这个),就是在脚本头部添加一句"SET sql_safe_updates = 0;",这样就不会报错了。
在自己写SQL脚本的时候这句话会很常用,因为在运行SQL脚本的时候相当于外部接入数据库修改数据,所以会有一个安全性判断的问题,一般这个判断是不给通过的,所以会报错。设置为0就可以跳过这个判断过程,脚本就可以顺利运行。




因为这个有一部分是笔者之前手动录入的数据,所以其实这段脚本对内容没有修改,但可以成功运行。

插入剩下的数据后,运行脚本,右边一列的数据就成功插入了。

SET sql_safe_updates = 0;
SELECT * FROM msi2017.finallistnum_result;
UPDATE finallistnum_result SET raceResult_TeamB_G1 = 'WIN' where raceResult_TeamA_G1 = 'LOSE';
四.内联UPDATE的并列和UPDATE的并列是类似的。UPDATE之间用分号隔开。


五.NOT NULL的不必要性和NULL的重要作用。
在建表的时候,尽量将非主键的其他键值默认值设置为NULL,否则在赋值的时候就会遇到这样的问题。
错误代码:1364。某个键没有默认值。如果建表的时候设置为NULL,就不会提示这个了。能少点麻烦就少点麻烦,后面需要改属性再改......没有默认值会很影响插入数据的效率。

所有的麻烦都是刚开始的自以为是......这样的话,插值就只能将前三列同时插入,要么就一列都插不进去,这个NOT NULL真的不能乱选啊......


这里说一点题外话:虽然SQL对关键字的大小写不敏感,但在大多数情况下,还是建议大家用大写,语句更统一,看着也更舒服不是。
六.复制性建表的SQL脚本。
CREATE TABLE table1 SELECT * FROM table2;
建立table1,并且将table2的整个表格照搬到table1。简言之,table1与table2在这个时间点唯一不同的只有表名,其他的东西都是完全相同的,包括表中截止这个时间点已经插入的数据,以及表格中每个键的属性,注释。
这里有个比较偏的东西,就是在这样复制表格的时候,表注释是不会复制的。这里说的表注释是指对整个表格的注释,而不是对每个键的单独注释。


这个表注释不复制,就得自己一个个写进去,如果表格比较多的话,还是挺麻烦的,这也算是MySQL少有的几个用户痛点。

use msi2017;
CREATE TABLE finallistnum_assistnum_top
select * from finallistnum_killnum_top;
七.枚举ENUM的使用细节。
这个格式真是刚开始把笔者坑惨了。要求很严格,必须是ENUM('value1','value2','value3')。必须是英文符号,单引号!

这里顺便说一下,SQL脚本在添加联合主键的时候,必须移除之前的主键,再添加联合主键。也就是说,不是从1+1=2,而是从1-1=0,到0+2=2的过程。

ALTER TABLE 'exhotel'.'room'
CHANGE COLUMN 'hotelNo''hotelNo' INT(6) NOT NULL,
DROP PRIMARY KEY,
ADD PRIMARY KEY('roomNo','hotelNo');
八.RENAME在Workbench后台脚本是无法被识别的。(好像是这样?)
查了很多资料,在Workbench后台写SQL脚本改表名好像是运行不了的。有图有真相。

话说回来,其实在Workbench中不需要在后台写SQL脚本改表名,直接切换到表属性页面就可以直接改了。不过在需要写大量SQL脚本来修改许多属性或者数据的时候,这样子的效率好像相对就低了点。
九.UNIQUE与主键的关联。
没有UNIQUE的表格是无法修改的,只能读取(Read Only),这个和主键联系起来可以理解。输入一行数据,如果没有主键,那怎么区分这行数据和其他数据的不同点?这也许在我们看来是可以区分的,但SQL是不能区分的,所以它强制每个表格都必须有UNIQUE INDEX(唯一索引),通常唯一索引就以主键为基础来建立。


插入唯一索引后,下方的Apply和Revert按钮就出现了,现在就可以对表格数据进行修改了。

十.清除表数据TRUNCATE的使用。
TRUNCATE是清除表中数据的关键字,它只清除数据,不移除表结构。


use msi2017;
TRUNCATE TABLE regseasonnum_createdamage_adc;
十一.接着说缺少UNIQUE INDEX(唯一索引)的表格操作。
之前说到只读,这种只读的程度是什么呢?是可以对整个表读取,也可以读取其中的部分键值。
设置UNIQUE INDEX之后,是不是就可以随意修改了呢?当然不是,在修改的时候,必须选择出主键列,否则SQL是不给你修改数据的权利的。
在我们的理解中,可能A(主键)的部分数据具有独特性,可以表征这就是A的数据,但SQL是无法识别这种附庸关系的。所以还是老老实实把主键带上......


在SELECT语句中加入UNIQUE INDEX(唯一索引)列之后,表格就可以修改了。

十二.唯一索引的添加位置。
笔者观察了一下,唯一索引的添加总是在SQL脚本的末尾,以 ADD UNIQUE INDEX 'indexname'('indexfor' ASC);为常用格式。这里indexname指这个索引的名字,indexfor指这个索引是为哪个键(列)建立的。


终于整理完了,下一部分应该就是大作业的SQL整理了。本SQL菜鸟还有很长的路要走啊......
SQL菜鸟学习札记(二)的更多相关文章
- SQL菜鸟学习札记(一)
刚开始学SQL,从最基础的语句开始写,用一个LOL数据库做实验.目前使用的工具是MySQL Workbench,感觉比较顺手,界面没花多久时间就读懂的差不多了,所以目前就使用这个工具来做SQL的学习了 ...
- SQL server学习(二)表结构操作、SQL函数、高级查询
数据库查询的基本格式为: select ----输出(显示)你要查询出来的值 from -----查询的依据 where -----筛选条件(对依据(数据库中存在的表)) group by ----- ...
- Python学习札记(二十五) 函数式编程6 匿名函数
参考:匿名函数 NOTE 1.Python对匿名函数提供了有限的支持. eg. #!/usr/bin/env python3 def main(): lis = list(map(lambda x: ...
- Microsoft SQL Server学习(二)
目录 关于数据库的语法: 1.创建数据库 create database 数据库名 on primary (主文件属性(name,filename,size等)) -用逗号隔开次要主要文件和次要文件 ...
- Microsoft SQL Server学习(二)--数据库的语法
关于数据库的语法 创建数据库 样例 名词概念 编写数据库代码的注意事项 关于文件语法 实例代码 关于数据库的语法: 1.创建数据库 create database 数据库名 on primary (主 ...
- SQL注入学习(二)
SQL注入点判断 ?id=35 +1/-1 查看页面是否发生变化 select * from tbName where id=$id 1.?id=35'数字后面加上[' or '' or )]来判断 ...
- SQL语句学习(二)
为一张表添加外键: 这里我们希望再建一张订单的表为t_order,包含order_id,customer_id和price: ) NOT NULL auto_increment PRIMARY KEY ...
- SQL函数学习(二):DATEADD() 函数
DATEADD() 函数在日期中添加或减去指定的时间间隔. 语法 DATEADD(datepart,number,date) date 参数是合法的日期表达式.number 是您希望添加的间隔数:对于 ...
- Python学习札记(二十九) 模块2
参考:使用模块 NOTE 1.内建sys模块: #!/usr/bin/env python3 import sys 'a test module' __author__ = 'wasdns' def ...
随机推荐
- cin问题 分类: c++ 2014-08-02 21:13 38人阅读 评论(0) 收藏
string s: while(cin>>s){ cout<<s<endl; } 当输入ss w ww w w 按enter时 输出为 ss w ww w ...
- 如何将Android Studio与华为软件开发云代码仓库无缝对接(二)
上篇文章:如何将Android Studio与华为软件开发云代码仓库无缝对接(一) 上一章讲了,如何用Android Studio以软件开发云代码仓库为基础,新建一个项目.接下来,这一章继续讲建好项目 ...
- 51nod 1008 N的阶乘 mod P
输入N和P(P为质数),求N! Mod P = ? (Mod 就是求模 %) 例如:n = 10, P = 11,10! = 3628800 3628800 % 11 = 10 Input 两 ...
- Password
Description Rivest是密码学专家.近日他正在研究一种数列E = {E[1],E[2],--,E[n]}, 且E[1] = E[2] = p(p为一个质数),E[i] = E[i-2]* ...
- 用户单独管理Jenkins的某些项目
管理用户: 建立用户: 安装Role-Based Strategy插件 安装插件后,进入系统设置页面,配置如下: 在系统管理页面点击Manage and Assign Roles进入角色管理页面: 1 ...
- python_装饰器_语法糖
什么是高阶函数? -- 把函数名当做参数传给另外一个函数,在另外一个函数中通过参数调用执行 #!/usr/bin/python3 __author__ = 'beimenchuixue' __blog ...
- MySQL中索引的基础知识
本文是关于MySQL中索引的基础知识.主要讲了索引的意义与原理.创建与删除的操作.并未涉及到索引的数据结构.高性能策略等. 一.概述 1.索引的意义:用于提高数据库检索数据的效率,提高数据库性能. 数 ...
- MySQL的grant,revoke使用
MySQL 赋予用户权限命令的简单格式可概括为: grant 权限 on 数据库对象 to 用户 一.grant 普通数据用户,查询.插入.更新.删除 数据库中所有表数据的权利. grant sele ...
- python3.4下django集成使用xadmin后台
环境:window7 x64.python3.4.django1.10 一.pip install xadmin安装报错 1.使用pip install xadmin命令安装可能报如下错误: 2.解决 ...
- Jmeter==HTTP信息头管理器的作用
HTTP信息头管理器在Jmeter的使用过程中起着很重要的作用,通常我们在通过Jmeter向服务器发送http请求(get或者post)的时候,往往后端需要一些验证信息,比如说web服务器需要带过去c ...