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.

随机推荐

  1. python中fork()函数生成子进程分析-乾颐堂

    python的os module中有fork()函数用于生成子进程,生成的子进程是父进程的镜像,但是它们有各自的地址空间,子进程复制一份父进程内存给自己,两个进程之 间的执行是相互独立的,其执行顺序可 ...

  2. phpmailer配置qq邮箱

    function send_email2($email = '*****@perspectivar.com'){ $this->autoRender = false; date_default_ ...

  3. Spring思维导图(IOC篇)

    写在前面 写过java的都知道:所有的对象都必须创建:或者说:使用对象之前必须先创建.而使用ioc之后,你就可以不再手动创建对象,而是从ioc容器中直接获取对象. 就好像我们无需考虑对象的销毁回收一样 ...

  4. YII2 全局设定 默认参数

    $gridviewSettings = [ 'export' => false, 'responsive' => true, 'floatHeader' => true, 'floa ...

  5. C#中遇到的方法总结

    1.Select(string filterExpression, string sort)  // 获取按照指定的排序顺序且与筛选条件相匹配的所有 System.Data.DataRow 对象的数组 ...

  6. SpringCloud 教程 | 第一篇: 服务的注册与发现Eureka(Finchley版本)

    一.spring cloud简介 鉴于<史上最简单的Spring Cloud教程>很受读者欢迎,再次我特意升级了一下版本,目前支持的版本为Spring Boot版本2.0.3.RELEAS ...

  7. Gulp资料大全:入门、插件、脚手架、包清单

    awesome-gulp中文版 一份gulp的资源,插件和使用实例清单, 致力于打造更好的前端工程构建流程. 被老外的awesome 清单刺激到,觉得有必要翻译一份,为国产的程序员们做点事情,本清单将 ...

  8. Maven整理笔记のMaven使用实践

    我们通过实践来补充Maven构建的生命周期. 第一步:配置POM 接着上一篇Maven使用,我们先创建一个名为helloworld的文件夹,在helloworld目录下创建pom.xml文件,pom. ...

  9. 网站页面多出&65279出现空白行的原因及解决方法

    模板文件生成html文件之后会在body开头处加入一个可见的控制符&#65279,导致页面头部会出现一个空白行.原因是页面的编码是UTF-8 + BOM. 这种编码方式一般会在windows操 ...

  10. java学习(四)static静态变量 和this

    java中的this /* this:是当前类的对象引用.简单的记,它就代表当前类的一个对象. 注意:谁调用这个方法,在该方法内部的this就代表谁. this的场景: 解决局部变量隐藏成员变量 */ ...