龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 数据库类 > MySQL 技术 >

一千行的MySQL学习笔记汇总(4)

时间:2014-10-06 15:30来源:网络整理 作者:网络 点击:
分享到:
2. unique 唯一索引(唯一约束) 使得某字段的值也不能重复。 3. null 约束 null不是数据类型,是列的一个属性。 表示当前列是否可以为null,表示什么都没有

2. unique 唯一索引(唯一约束)
    使得某字段的值也不能重复。
   
3. null 约束
    null不是数据类型,是列的一个属性。
    表示当前列是否可以为null,表示什么都没有。
    null, 允许为空。默认。
    not null, 不允许为空。
    insert into tab values (null, 'val');
        -- 此时表示将第一个字段的值设为null, 取决于该字段是否允许为null
   
4. default 默认值属性
    当前字段的默认值。
    insert into tab values (default, 'val');    -- 此时表示强制使用默认值。
    create table tab ( add_time timestamp default current_timestamp );
        -- 表示将当前时间的时间戳设为默认值。
        current_date, current_time

5. auto_increment 自动增长约束
    自动增长必须为索引(主键或unique)
    只能存在一个字段为自动增长。
    默认为1开始自动增长。可以通过表属性 auto_increment = x进行设置,或 alter table tbl auto_increment = x;

6. comment 注释
    例:create table tab ( id int ) comment '注释内容';

7. foreign key 外键约束
    用于限制主表与从表数据完整性。
    alter table t1 add constraint `t1_t2_fk` foreign key (t1_id) references t2(id);
        -- 将表t1的t1_id外键关联到表t2的id字段。
        -- 每个外键都有一个名字,可以通过 constraint 指定

    存在外键的表,称之为从表(子表),外键指向的表,称之为主表(父表)。

    作用:保持数据一致性,完整性,主要目的是控制存储在外键表(从表)中的数据。

    MySQL中,可以对InnoDB引擎使用外键约束:
    语法:
    foreign key (外键字段) references 主表名 (关联字段) [主表记录删除时的动作] [主表记录更新时的动作]
    此时需要检测一个从表的外键需要约束为主表的已存在的值。外键在没有关联的情况下,可以设置为null.前提是该外键列,没有not null。

    可以不指定主表记录更改或更新时的动作,那么此时主表的操作被拒绝。
    如果指定了 on update 或 on delete:在删除或更新时,有如下几个操作可以选择:
    1. cascade,级联操作。主表数据被更新(主键值更新),从表也被更新(外键值更新)。主表记录被删除,从表相关记录也被删除。
    2. set null,设置为null。主表数据被更新(主键值更新),从表的外键被设置为null。主表记录被删除,从表相关记录外键被设置成null。但注意,要求该外键列,没有not null属性约束。
    3. restrict,拒绝父表删除和更新。

    注意,外键只被InnoDB存储引擎所支持。其他引擎是不支持的。

建表规范

  -- Normal Format, NF
    - 每个表保存一个实体信息
    - 每个具有一个ID字段作为主键
    - ID主键 + 原子表
  -- 1NF, 第一范式
    字段不能再分,就满足第一范式。
  -- 2NF, 第二范式
    满足第一范式的前提下,不能出现部分依赖。
    消除符合主键就可以避免部分依赖。增加单列关键字。
  -- 3NF, 第三范式
    满足第二范式的前提下,不能出现传递依赖。
    某个字段依赖于主键,而有其他字段依赖于该字段。这就是传递依赖。
    将一个实体信息的数据放在一个表内实现。


/* select */ ------------------

select [all|distinct] select_expr from -> where -> group by [合计函数] -> having -> order by -> limit

a. select_expr
  -- 可以用 * 表示所有字段。
    select * from tb;
  -- 可以使用表达式(计算公式、函数调用、字段也是个表达式)
    select stu, 29+25, now() from tb;
  -- 可以为每个列使用别名。适用于简化列标识,避免多个列标识符重复。
    - 使用 as 关键字,也可省略 as.
    select stu+10 as add10 from tb;

b. from 子句
  用于标识查询来源。
  -- 可以为表起别名。使用as关键字。
    select * from tb1 as tt, tb2 as bb;
  -- from子句后,可以同时出现多个表。
    -- 多个表会横向叠加到一起,而数据会形成一个笛卡尔积。
    select * from tb1, tb2;

c. where 子句
  -- 从from获得的数据源中进行筛选。
  -- 整型1表示真,0表示假。
  -- 表达式由运算符和运算数组成。
    -- 运算数:变量(字段)、值、函数返回值
    -- 运算符:
      =, <=>, <>, !=, <=, <, >=, >, !, &&, ||, 
      in (not) null, (not) like, (not) in, (not) between and, is (not), and, or, not, xor
      is/is not 加上ture/false/unknown,检验某个值的真假
      <=>与<>功能相同,<=>可用于null比较

d. group by 子句, 分组子句
  group by 字段/别名 [排序方式]
  分组后会进行排序。升序:ASC,降序:DESC
  
  以下[合计函数]需配合 group by 使用:
  count 返回不同的非NULL值数目  count(*)、count(字段)
  sum 求和
  max 求最大值
  min 求最小值
  avg 求平均值
  group_concat 返回带有来自一个组的连接的非NULL值的字符串结果。组内字符串连接。

e. having 子句,条件子句
  与 where 功能、用法相同,执行时机不同。
  where 在开始时执行检测数据,对原数据进行过滤。
  having 对筛选出的结果再次进行过滤。
  having 字段必须是查询出来的,where 字段必须是数据表存在的。
  where 不可以使用字段的别名,having 可以。因为执行WHERE代码时,可能尚未确定列值。
  where 不可以使用合计函数。一般需用合计函数才会用 having
  SQL标准要求HAVING必须引用GROUP BY子句中的列或用于合计函数中的列。

f. order by 子句,排序子句
  order by 排序字段/别名 排序方式 [,排序字段/别名 排序方式]...
  升序:ASC,降序:DESC
  支持多个字段的排序。

g. limit 子句,限制结果数量子句
  仅对处理好的结果进行数量限制。将处理好的结果的看作是一个集合,按照记录出现的顺序,索引从0开始。
  limit 起始位置, 获取条数
  省略第一个参数,表示从索引0开始。limit 获取条数

h. distinct, all 选项
  distinct 去除重复记录
  默认为 all, 全部记录


/* UNION */ ------------------
  将多个select查询的结果组合成一个结果集合。
  SELECT ... UNION [ALL|DISTINCT] SELECT ...
  默认 DISTINCT 方式,即所有返回的行都是唯一的
  建议,对每个SELECT查询加上小括号包裹。
  ORDER BY 排序时,需加上 LIMIT 进行结合。
  需要各select查询的字段数量一样。
  每个select查询的字段列表(数量、类型)应一致,因为结果中的字段名以第一条select语句为准。


/* 子查询 */ ------------------
  - 子查询需用括号包裹。
-- from型
  from后要求是一个表,必须给子查询结果取个别名。
  - 简化每个查询内的条件。
  - from型需将结果生成一个临时表格,可用以原表的锁定的释放。
  - 子查询返回一个表,表型子查询。
  select * from (select * from tb where id>0) as subfrom where id>1;
-- where型
  - 子查询返回一个值,标量子查询。
  - 不需要给子查询取别名。
  - where子查询内的表,不能直接用以更新。
  select * from tb where money = (select max(money) from tb);
  -- 列子查询
    如果子查询结果返回的是一列。
    使用 in 或 not in 完成查询
    exists 和 not exists 条件
      如果子查询返回数据,则返回1或0。常用于判断条件。
      select column1 from t1 where exists (select * from t2);
  -- 行子查询
    查询条件是一个行。
    select * from t1 where (id, gender) in (select id, gender from t2);
    行构造符:(col1, col2, ...) 或 ROW(col1, col2, ...)
    行构造符通常用于与对能返回两个或两个以上列的子查询进行比较。

  -- 特殊运算符
  != all()  相当于 not in
  = some()  相当于 in。any 是 some 的别名
  != some()  不等同于 not in,不等于其中某一个。
  all, some 可以配合其他运算符一起使用。


/* 连接查询(join) */ ------------------
  将多个表的字段进行连接,可以指定连接条件。
-- 内连接(inner join)
  - 默认就是内连接,可省略inner。
  - 只有数据存在时才能发送连接。即连接结果不能出现空行。
  on 表示连接条件。其条件表达式与where类似。也可以省略条件(表示条件永远为真)
  也可用where表示连接条件。
  还有 using, 但需字段名相同。 using(字段名)

  -- 交叉连接 cross join
    即,没有条件的内连接。
    select * from tb1 cross join tb2;
-- 外连接(outer join)
  - 如果数据不存在,也会出现在连接结果中。
  -- 左外连接 left join
    如果数据不存在,左表记录会出现,而右表为null填充
  -- 右外连接 right join
    如果数据不存在,右表记录会出现,而左表为null填充
-- 自然连接(natural join)
  自动判断连接条件完成连接。
  相当于省略了using,会自动查找相同字段名。
  natural join
  natural left join
  natural right join

select info.id, info.name, info.stu_num, extra_info.hobby, extra_info.sex from info, extra_info where info.stu_num = extra_info.stu_id;

/* 导入导出 */ ------------------
select * into outfile 文件地址 [控制格式] from 表名;  -- 导出表数据
load data [local] infile 文件地址 [replace|ignore] into table 表名 [控制格式];  -- 导入数据
  生成的数据默认的分隔符是制表符
  local未指定,则数据文件必须在服务器上
  replace 和 ignore 关键词控制对现有的唯一键记录的重复的处理
-- 控制格式
fields  控制字段格式
默认:fields terminated by '\t' enclosed by '' escaped by '\\'
  terminated by 'string'  -- 终止
  enclosed by 'char'    -- 包裹
  escaped by 'char'    -- 转义
  -- 示例:
    SELECT a,b,a+b INTO OUTFILE '/tmp/result.text'
    FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
    LINES TERMINATED BY '\n'
    FROM test_table;
lines  控制行格式
默认:lines terminated by '\n'
  terminated by 'string'  -- 终止
  
/* insert */ ------------------
select语句获得的数据可以用insert插入。

可以省略对列的指定,要求 values () 括号内,提供给了按照列顺序出现的所有字段的值。
  或者使用set语法。
  insert into tbl_name set field=value,...;

可以一次性使用多个值,采用(), (), ();的形式。
  insert into tbl_name values (), (), ();

可以在列值指定时,使用表达式。
  insert into tbl_name values (field_value, 10+10, now());
可以使用一个特殊值 default,表示该列使用默认值。
  insert into tbl_name values (field_value, default);

可以通过一个查询的结果,作为需要插入的值。
  insert into tbl_name select ...;

可以指定在插入的值出现主键(或唯一索引)冲突时,更新其他非主键列的信息。
  insert into tbl_name values/set/select on duplicate key update 字段=值, …;

/* delete */ ------------------
DELETE FROM tbl_name [WHERE where_definition] [ORDER BY ...] [LIMIT row_count]

按照条件删除

指定删除的最多记录数。Limit

可以通过排序条件删除。order by + limit

支持多表删除,使用类似连接语法。
delete from 需要删除数据多表1,表2 using 表连接操作 条件。

/* truncate */ ------------------
TRUNCATE [TABLE] tbl_name
清空数据
删除重建表

精彩图集

赞助商链接