温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MySQL主健、索引讲义

发布时间:2020-04-24 14:25:26 来源:亿速云 阅读:239 作者:三月 栏目:数据库

下文内容主要给大家带来MySQL主健、索引讲义,这里所讲到的知识,与书籍略有不同,都是亿速云专业技术人员在与用户接触过程中,总结出来的,具有一定的经验分享价值,希望给广大读者带来帮助。 

<--目录-->

1)主健

   1、操作表的约束

     (1)非空约束

     (2)字段默认值

     (3)唯一约束

     (4)主健约束

     (5)添加主健(重点)

     (6) 自动增加  

2)索引

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

   2、创建唯一索引

   3、创建全文索引

   4、创建多列索引

   5、删除索引

MySQL主健、索引讲义

【主健】

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;

对于以上关于MySQL主健、索引讲义,如果大家还有更多需要了解的可以持续关注我们亿速云的行业推新,如需获取专业解答,可在官网联系售前售后的,希望该文章可给大家带来一定的知识更新。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI