head first
1, insert 单引号时,使用/转义
2, 不要用NULL, 查找时使用isNull 来判断。
3, 用and / or 连接两个not 时,要写两个NOT
4,delete from table //删除全部表内容
5, 改变N个列
ALTER TABLE project
CHANGE COLUMN description new_desc VARCHAR(100),
CHANGE COLUMN contents new_contents VARCHAR(30);
修改类型
ALTER TABLE project
MODIFY COLUMN contents VARCHAR(120);
ALTER TABLE project
ADD COLUMN start_date DEC(7,2);//记得这是什么类型了吗
DROP COLUMN …
6,MODIFY 无法重新排列列的顺序,只有添加列才是调整序的好时机。
7,超大型的
UPDATE my_table
SET new_col=
CASE
WHEN col1 = value1 THEN newva1
WHEN col2 = value2 THEN newva2
ELSE newval3
END;
8, ORDER BY 根据某个列(某几个)列返回结果
DESC 有时叫做description 有时又叫descending
SELECT *
FROM T
ORDER BY t1 ASC, p1 DESC;
9, SUM 把括号内出现的列值加总
SELECT name, SUM(salary)
FROM sales
GROUP BY name //分组
ORDER BY SUM(salary) DESC;// 必须根据求和所用的列排序
10, AVG 配GROUP BY
SELECT name, AVG(salary)
FROM sales
GROUP BY name; //AVG 先把组内所有值求和,再求平均。
11, MIN / MAX
SELECT name, MAX(salary)
FROM sales
GROUP BY name; // 返回每个人拿过的最高工资
12,DISTINCT 是个关键字不是函数,所以不用括号
SELECT DISTINCT sdate
FROM sales
ORDER BY sdate;// 没有重复的日期
SELECT COUNT(DISTINCT sdate)
FROM sales; // 因为COUNT 只返回一个值,不需要ORDER DY,
13,LIMIT 1,1; //SQL 从0开始计数, 所以取第二条
14, 模式SCHEMA 用于表达数据库内的结构,表和列,他们之间相互连接方式。
15, 外键使用的主键也称父键。主键所在的表称为父表。
外键用于确认一张表中的行与另张表中的行相对应。外键值可为NULL即使主键不可为NULL.外键不需要唯一性。
可以通过约束来保证外键有意义,
插入外键列的值必须已经存在于父表的来源列中,这是引用完整性。
16,1NF 数据列只包含原子性的值 没有重复的数据组
17, T.x -> T.y // 从右到左读作,在关系表T中,y列依赖于x列,
18,2NF 没有部分依赖的1NF 或,符合1NF的表只有一列主键就是2NF。
19,3NF 没有传递依赖的2NF
20,内联
交叉连接CROSS JOIN 默认不写就是交叉,返回两张表的每一行相乘结果
相等连接INNER JOIN equijoin 不等连接..ON T.a <> S.a
自然连接NATURAL JOIN 没有ON,利用同列名的连接,
21, IN , NOT IN … NOT EXISTS 比比效率吧
22,外连接
LEFT OUTER JOIN 接收左表中所有行,用这些行与右表匹配。当左与右有一对多关系时有用。结果集中的NULL行表示右表中没有相符记录行。
RIGHT OUTER JOIN
一个表可同时作外连接左右表
23, UNION 规则
每个SELECT 列的数量一致,表达式与统计函数相同,
SQL 会默认清除重复值 如果不想清除使用UNION ALL
列的数据类型相同或可转
如果想对结果排序,请在最后一条SELECT 加入ORDER BY 能排列整个结果集
INTERSECT A&B
EXCEPT A-B
24,视图
CREATE VIEW name AS
...
25,再背一遍ACID
atomicity
consistency
isolation
durability
26,事务管理
START TRANSACTION;//追踪后续所有SQL
COMMIT;//提交之前数据库不会有任何行为
ROLLBACK;//回滚到事务开始前。
27,密码
SET PASSWORD FOR 'root' @ 'localhost' PASSOWRD('XXXX');
ALTER USER ROOT IDENTIFIED BY new-password;
GRANT SELECT ON
table1
TO user1;
REVOKE SELECT ON
table1
FROM user1;
REVOKE DELETE ON
table1
FROM user1 CASCADE;
i am sorry i have not appreciated the strong point of this bookl.
随机推荐
- AngularJS基本使用
简介 AngularJS是Google开源的前端JS结构化框架 Angular关注的是动态展示页面数据, 并与用户进行交互.其主体不再是DOM,而是页面中的动态数据 AngularJS特性(优点) 双 ...
- 六)iframe 及父子页面之间获取元素、方法调用
http://www.w3school.com.cn/tags/tag_iframe.asp father.html <!DOCTYPE html> <html> <he ...
- 编写高质量代码改善C#程序的157个建议——建议121:为应用程序设定运行权限
建议121:为应用程序设定运行权限 在某些情况下,可能存在这样的需求:只有系统管理员才能访问某应用程序的若干功能.这个时候,可以结合.NET中提供的代码访问安全性(Code Access Securi ...
- Elasticsearch5.6.8 安装问题集锦
今天在内部linux环境安装Elasticsearch5.6.8时遇到一些问题,主要如下 使用Elasticsearch5.6.8 必须安装jdk1.8 [elsearch@vm-mysteel-dc ...
- Alpha阶段项目复审(菜就完事了队)
Alpha阶段项目复审 小组 优点 缺点 名次 天冷记得穿秋裤队 实现的功能完整,可以离线下载 下载不稳定,大文件无法下载 1 中午吃啥队 使用方便,操作简单 界面适应不够好 2 只会嘤嘤嘤队 游戏和 ...
- C++裁剪文件,截断文件,_chsize()
errno_t _chsize_s( int fd, __int64 size ); 详见msdn知识库 _chsize将文件裁剪为指定大小,大小的度量方法与 long ftell(FILE * fp ...
- 【题解】 [NOI1999]生日蛋糕
题面 传送门 Solution 搜索每一层的半径和高度,然后加入一些剪枝就好了. #include<stdio.h> #include<stdlib.h> #include&l ...
- Python在Android系统上运行
下载 Scripting Layer for Android (SL4A) https://github.com/damonkohler/sl4a https://www.tutorialspoint ...
- libz.dylib框架怎么导入
1.General下 2.点击+号在弹出的对话框选择addother 3.在弹出的对话框中输入"cmd"+"shift"+"g" 输入/us ...
- Echart自定义y轴刻度信息2
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...