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 ...
随机推荐
- 51. leetcode 530. Minimum Absolute Difference in BST
530. Minimum Absolute Difference in BST Given a binary search tree with non-negative values, find th ...
- OpenCV1.0在VC ++6.0下的配置
1.本人使用win7操作系统,首先要预装VC++6.0,安装方法不再赘述. 2.在OpenCV官方网站下载OpenCV的安装文件"OpenCV_1.0.EXE"(参考链接:http ...
- 表达式求值(二叉树方法/C++语言描述)(五)
本例中的二叉树图是使用Graphviz绘制的(Graphviz官网),在Ubuntu Linux下可以使用apt-get命令安装它: sudo apt-get install graphviz 表达式 ...
- 关于SQL语句条件值写中文查不到的问题
在使用jdbc链接MySQL执行SQL语句的时候,sql语句中的where条件,参数值带中文,则查询不到结果,而where条件,参数值都为数字或字母时可以正常查询, 原因是mysql的characte ...
- Red Hat 9.0 Linux 分辨率修改
Red Hat 9.0 Linux 分辨率修改 我是在VMware Workstation中装了一个红帽的Linux系统,装上之后发现分辨率有点低,是800x600的,看着很不舒服,然后就想着怎么样可 ...
- NYOJ 71 独木舟上的旅行(贪心)
独木舟上的旅行 时间限制:3000 ms | 内存限制:65535 KB 难度:2 描述 进行一次独木舟的旅行活动,独木舟可以在港口租到,并且之间没有区别.一条独木舟最多只能乘坐两个人,且乘客 ...
- 迷宫 洛谷 p1605
题目背景 迷宫 [问题描述] 给定一个N*M方格的迷宫,迷宫里有T处障碍,障碍处不可通过.给定起点坐标和 终点坐标,问: 每个方格最多经过1次,有多少种从起点坐标到终点坐标的方案.在迷宫 中移动有上下 ...
- ACM做题过程中的一些小技巧
1.一般用C语言节约空间,要用C++库函数或STL时才用C++; cout.cin和printf.scanf最好不要混用. 2.有时候int型不够用,可以用long long或__int64型(两个下 ...
- 设计模式,Let's Go! (上)
* { color: #3e3e3e } body { font-family: "Helvetica Neue", Helvetica, "Hiragino Sans ...
- Orleans的集群构建
Orleans的集群构建 这是Orleans系列文章中的一篇.首篇文章在此 听闻一周前,微软公布了.net core2.0,以及各种各样的其他core2.0.大家都很兴奋.微妈的诚意真是满满的.这次开 ...