美文网首页
mysql--修饰字段的常用属性

mysql--修饰字段的常用属性

作者: octobert | 来源:发表于2017-12-16 22:39 被阅读0次

    1.auto_increment

    auto_increment能为新插入的行赋一个唯一的整数标识符。为列赋此属性将为每个新插入的行赋值为上一次插入的ID+1。

    MySQL要求将auto_increment属性用于作为主键的列。此外,每个表只允许有一个auto_increment列

    id smallint auto_increment primary key

    2.binary

    binary属性只用于char和varchar值。当为列指定了该属性时,将以区分大小写的方式排序。与之相反,忽略binary属性时,将使用不区分大小写的方式排序。

    hostname char(25) not null default ''

    3.default

    default属性确保在没有任何值可用的情况下,赋予某个常量值,这个值必须是常量,因为MySQL不允许插入函数或表达式值。此外,此属性无法用于BLOB或TEXT列。如果已经为此列指定了NULL属性,没有指定默认值时默认值将为NULL,否则默认值将依赖于字段的数据类型。

    subscribed enum('0','1') not null default '0'

    4.index

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

    create table employees (
        id int not null auto_increment,
        firstname varchar(15) not null default '',
        lastname char(20) not null default '',
        email varchar(45) not null default '',
        phone char(11) not null default 0,
        index lastname(lastname),
        primary key(id)
    )engin=InnoDB,charset=utf8;
    

    我们也可以利用MySQL的create index命令在创建表之后增加索引:
    代码如下:

    create index lastname on employees (lastname(7));

    这一次只索引了名字的前7个字符,因为可能不需要其它字母来区分不同的名字。因为使用较小的索引时性能更好,所以应当在实践中尽量使用小的索引。

    5.not null

    如果将一个列定义为not null,将不允许向该列插入null值。建议在重要情况下始终使用not null属性,因为它提供了一个基本验证,确保已经向查询传递了所有必要的值。

    6.null

    为列指定null属性时,该列可以保持为空,而不论行中其它列是否已经被填充。记住,null精确的说法是“无”,而不是空字符串或0。

    7.primary key

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

    PRIMARY KEY(column_name)

    8.unique

    被赋予unique属性的列将确保所有值都有不同的值,只是null值可以重复。一般会指定一个列为unique,以确保该列的所有值都不同。

    email varchar(45) unique

    9.zerofill

    zerofill属性可用于任何数值类型,用0填充所有剩余字段空间。例如,无符号int的默认宽度是10;因此,当“零填充”的int值为4时,将表示它为0000000004。

    orderid int unsigned zerofill not null

    10.unsigned

    表示无符号的,用于数字类型,不能出现符号

    相关文章

      网友评论

          本文标题:mysql--修饰字段的常用属性

          本文链接:https://www.haomeiwen.com/subject/wctewxtx.html