5MySQL主健和索引

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了5MySQL主健和索引相关的知识,希望对你有一定的参考价值。

<--目录-->

1)主健

   1、操作表的约束

     (1)非空约束

     (2)字段默认值

     (3)唯一约束

     (4)主健约束

     (5)添加主健(重点)

     (6) 自动增加  

2)索引

   1、创建普通索引(重点)

   2、创建唯一索引

   3、创建全文索引

   4、创建多列索引

   5、删除索引


【主健】

1、操作表的约束

###########################################################################

约束关健字                       含义                                     #

not null                   约束的字段值不能为空                           #

default                    设置字段的默认值                               #

unique key (uk)            约束字段的值是唯一                             #

primary key (pk)           约束字段为表的主健,可以作为该记录的唯一标识   #

auto_increment             约束字段的值为自动增加                         #

foreign key (fk)           约束字段为表的外健                             #

###########################################################################


#设置非空约束

#解释:设置了非空约束,字段内容则不允许为空

mysql> create table t1(

    -> id int(20) not null,

    -> loc varchar(40)

    -> );


#设置字段的默认值

#解释:当为表中某个字段插入记录没有给他赋值,则系统会为这个字段插入默认值

mysql> create table t1(

    -> id int(20) not null,

    -> dname varchar(20) default ‘cjgong‘,

    -> loc varchar(40)

    -> );


#设置唯一约束

#解释:数据库表中某个字段的内容不允许重复

mysql> create table t1(

    -> id int(20) not null,

    -> dname varchar(20) unique,

    -> loc varchar(40)

    -> );


#设置主健约束

#解释:用数据库表中的某个字段来标识所有记录

mysql> create table t1(

    -> id int(20) primary key,

    -> loc varchar(40)

    -> );


#添加主健

alter table student change id id int primary key auto_increment;


#设置字段值自动增加

#解释:当为数据库表中插入新记录时,字段上的值会自动生成唯一的ID

mysql> create table t1(

    -> id int(20) primary key auto_increment,

    -> loc varchar(40)

    -> );


【索引】

1、创建普通索引

#解释:普通索引不附加任何限制条件,可以创建在任何数据类型的字段上

mysql> create table t1(

    -> 字段名 数据库类,

    -> 字段名 数据库类,

    -> ... ...

    -> index  索引名(字段名)

    -> );


#创建表时创建普通索引

mysql> create table t1(

    -> id int(20) primary key auto_increment,

    -> loc varchar(40)

    -> index index_deptno(deptno)

    -> );


#在已经存在的表上创建普通索引

mysql> create index 索引名 on 表名(字段名)

mysql> create index index_deptno on t1(deptno)


#通过sql语句alter table创建普通索引

mysql> alter table table_name add index 索引名(字段名);

mysql> alter table t1 add index index_deptno(deptno);


2、创建和查看唯一索引

mysql> create table t1(

    -> 字段名 数据库类,

    -> 字段名 数据库类,

    -> ... ...

    -> unique index  索引名(字段名)

    -> );


#创建表时创建唯一索引

#解释:创建索引时,索引的值必段是唯一的

mysql> create table t1(

    -> id int(20) primary key auto_increment,

    -> loc varchar(40)

    ->  unique index index_depktno(deptno)

    -> );


#在已经存在的表上创建唯一索引

mysql> create unique index 索引名 on 表名(字段名)

mysql> create unique index index_deptno on t1(deptno)


#通过sql语句alter table创建唯一索引

mysql> alter table table_name add unique index 索引名(字段名);

mysql> alter table t1 add unique index index_deptno(deptno);


3、创建和查看全文索引

#解释:全文索引要关联在char、varchar、text字段上,以便快速查询数量较大的字符串类型的字段

mysql> create table t1(

    -> 字段名 数据库类,

    -> 字段名 数据库类,

    -> ... ...

    -> fulltext index  索引名(字段名)

    -> );


#创建表时创建全文索引

mysql> create table t1(

    -> id int(20) primary key auto_increment,

    -> loc varchar(40)

    ->  fulltext index index_depktno(deptno)

    -> );


#在已经存在的表上创建全文索引

mysql> create fulltext index 索引名 on 表名(字段名)

mysql> create fulltext index index_deptno on t1(deptno)


#通过sql语句alter table创建全文索引

mysql> alter table table_name add fulltext index 索引名(字段名);

mysql> alter table t1 add unique fulltext index index_deptno(deptno);


4、创建和查看多列索引

#解释:多列索引在创建索引时,所关联的字段是多个字段,虽然可以通过所关联的字段进行查询,但是只有查询条件中使用了所关联字段中的第一个字段,多列索引才会被使用

mysql> create table t1(

    -> 字段名 数据库类,

    -> 字段名 数据库类,

    -> ... ...

    -> fulltext index  索引名(字段名)

    -> );


#创建表时创建多列索引

mysql> create table t1(

    -> 字段名 数据库类,

    -> 字段名 数据库类,

    -> ... ...

    -> index  索引名(字段名1,字段名2)

    -> );


#创建表时创建多列索引

mysql> create table t1(

    -> id int(20) primary key auto_increment,

    -> loc varchar(40)

    -> index index_deptno(deptno,id)

    -> );


#在已经存在的表上创建多列索引

mysql> create index 索引名 on 表名(字段名1,字段名2)

mysql> create index index_deptno on t1(deptno,id)


#通过sql语句alter table创建多列索引

mysql> alter table table_name add index 索引名(字段名1,字段名2);

mysql> alter table t1 add index index_deptno(deptno,id);


5、删除索引

语法形式如下:

drop index 索引名字 on 表名字

mysql> drop index index_deptno on t1;


本文出自 “wsyht的博客” 博客,请务必保留此出处http://wsyht2015.blog.51cto.com/9014030/1787651

以上是关于5MySQL主健和索引的主要内容,如果未能解决你的问题,请参考以下文章

MYSQL中的普通索引,主健,唯一,全文索引区别

“access索引或主关键字不能包含一个空 (Null)值”是啥意思?怎么解决?

索引优化原则及Oracle中索引总结

mysql中的键和索引

mysq数据库常用

健和积分是什么怎么操作的?