首页 / MYSQL / 5、MySQL主健和索引
5、MySQL主健和索引
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了5、MySQL主健和索引,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含5138字,纯文字阅读大概需要8分钟。
内容图文
![5、MySQL主健和索引](/upload/InfoBanner/zyjiaocheng/465/c2c58505cdce4d5b88f0d3f362b5b38e.jpg)
<--目录-->
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
5、MySQL主健和索引
标签:mysql null primary default 主健
本文系统来源:http://wsyht2015.blog.51cto.com/9014030/1787651
内容总结
以上是互联网集市为您收集整理的5、MySQL主健和索引全部内容,希望文章能够帮你解决5、MySQL主健和索引所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。