一、常用属性

1、auto_increment:自增长

  auto_increment能为新插入的行赋一个唯一的整数标识符。为列赋此属性将为每个新插入的行赋值为上一次插入的ID+1。
  MySQL要求将auto_increment属性用于作为主键的列。此外,每个表只允许有一个auto_increment列。

2、binary:区分大小写
        binary属性只用于char和varchar值。当为列指定了该属性时,将以区分大小写的方式排序。与之相反,忽略binary属性时,将使用不区分大小写的方式排序。
3、default:默认值
        default属性确保在没有任何值可用的情况下,赋予某个常量值,这个值必须是常量,因为MySQL不允许插入函数或表达式值。此外,此属性无法用于BLOB或TEXT列。如果已  经为此列指定了NULL属性,没有指定默认值时默认值将为NULL,否则默认值将依赖于字段的数据类型。

4、index:索引
        如果所有其他因素都相同,要加速数据库查询,使用索引通常是最重要的一个步骤。索引一个列会为该列创建一个有序的键数组,每个键指向其相应的表行。以后针对输入条件  可以搜索这个有序的键数组,与搜索整个未索引的表相比,这将在性能方面得到极大的提升

create table employees
  (
  id varchar(9) not null,
  firstname varchar(15) not null,
  lastname varchar(25) not null, 
  email varchar(45) not null,
  phone varchar(10) not null,
  index lastname(lastname),
  primary key(id)
  );

  添加索引

ALTER TABLE <表名> ADD INDEX (<字段>);

5、not null:非空约束
  如果将一个列定义为not null,将不允许向该列插入null值。建议在重要情况下始终使用not null属性,因为它提供了一个基本验证,确保已经向查询传递了所有必要的值。
  null
  为列指定null属性时,该列可以保持为空,而不论行中其它列是否已经被填充。记住,null精确的说法是“无”,而不是空字符串或0。

6、primary key:主键
  primary key属性用于确保指定行的唯一性。指定为主键的列中,值不能重复,也不能为空。为指定为主键的列赋予auto_increment属性是很常见的,因为此列不必与行数据有任  何关系,而只是作为一个唯一标识符。主键又分为以下两种:
  (1)、单字段主键
  如果输入到数据库中的每行都已经有不可修改的唯一标识符,一般会使用单字段主键。注意,此主键一旦设置就不能再修改。
  (2)、多字段主键
  如果记录中任何一个字段都不可能保证唯一性,就可以使用多字段主键。这时,多个字段联合起来确保唯一性。如果出现这种情况,指定一个auto_increment整数作为主键是更  好的办法。

7、unique:唯一约束
  被赋予unique属性的列将确保所有值都有不同的值,只是null值可以重复。一般会指定一个列为unique,以确保该列的所有值都不同。
  email varchar(45) unique   email不允许重复
8、zerofill:零填充
  zerofill属性可用于任何数值类型,用0填充所有剩余字段空间。例如,无符号int的默认宽度是10;因此,当“零填充”的int值为4时,将表示它为0000000004。
  orderid int unsigned zerofill not null

二、约束

1、什么是mysql约束?
  约束是一种限制,它通过对表的行或列的数据做出限制,来确保表的数据的完整性、唯一性。
  常见约束
2、主键约束 primary key
  主键约束相当于   唯一约束 + 非空约束  的组合,主键约束列不允许重复,也不允许出现空值。
  每个表最多只允许一个主键,建立主键约束可以在列级别创建,也可以在表级别创建。
  当创建主键的约束时,系统默认会在所在的列和列组合上建立对应的唯一索引。
3、复合主键
  在一个数据表中通过多个字段作为主键来确定一条记录,那么,多个字段组成的就是复合主键

create table student(
  name varchar(30) comment '姓名',
  age smallint comment '年龄',
  sex enum('男','女') comment '性别',
  primary key(name,age)
  )
4、联合主键
  当两个数据表形成的是多对多的关系,那么需要通过两个数据表的主键来组成联合主键,就可以确定每个数据表的其中一条记录了
  学生表:student=================================
  -------------------
  create table student(
  id mediumint  auto_increment comment '主键id',
  name varchar(30) comment '姓名',
  age smallint comment '年龄',
  primary key(id)
  )
  engine = myisam,
  charset = utf8,
  comment = '学生'
  课程表:course=============================
  ---------------------
  create table course(
  id mediumint  auto_increment comment '主键id',
  name varchar(30) comment '课程名称',
  primary key(id)
  )
  engine = myisam,
  charset = utf8,
  comment = '课程'
  学生课程表:stu_cour==========================
  ---------------------------
  create table IF NOT EXISTS stu_cour(
  id mediumint  auto_increment comment '主键id',
  stu_id mediumint comment '学生表id',
  cour_id mediumint comment '课程表id',
  primary key(id)
  )

5、外键约束 foreign key
  外键约束是保证一个或两个表之间的参照完整性,外键是构建于一个表的两个字段或是两个表的两个字段之间的参照关系

  外键使用规范
  (1)、从表的字段必须与外键类型同样(如上。分数表 stu 的类型必须和学生表 sid 的类型同样,比方都是 int(10) 类型)
  (2)、外键必须是主表的唯一键(如上。学生表 sid 是主键,而主键是唯一的。所以能够作为分数表 stu 的外键)
  (3)、有关联的字段(如上,分数表之所以使用学生表的 sid 是由于两者有关联,分数表记录的是学生的分数,而学生能够用 sid 来唯 一标识)
  (4)、避免使用复合键(也就是说从表能够同一时候引用多个外表的字段作为一个外键,一般不推荐这样的做法)

  添加外键
  (1)、FOREIGN KEY (从表字段) REFERENCES 主表 (字段)
  (2)、alter table 从表表名 add constraint FK_ID foreign key(你的外键字段名) REFERENCES 外表表名(对应的表的主键字段名);
  为什么说外键能保持数据的一致性、完整性
  在设置外键的情况下。你插入从表的外键字段的值必需要求在主表的主键字段能找到。 同一时候。假设你要主表的主键字段。必须保证从表中没有引用该字段值的列(也就是没  有跟这一列建立外键),否则就没法删除。
6、唯一约束:unique
  唯一约束是指定table的列或列组合不能重复,保证数据的唯一性。
  唯一约束不允许出现重复的值,但是可以为多个null。
  同一个表可以有多个唯一约束,多个列组合的约束。
  在创建唯一约束时,如果不给唯一约束名称,就默认和列名相同。
  唯一约束不仅可以在一个表内创建,而且可以同时多表创建组合唯一约束。
7、非空约束:not null
        非空约束用于确保当前列的值不为空值,非空约束只能出现在表对象的列上。
  Null类型特征:
  所有的类型的值都可以是null,包括int、float 等数据类型
8、默认值:default