当前位置:Gxlcms > 数据库问题 > Linux-数据库4

Linux-数据库4

时间:2021-07-01 10:21:17 帮助过:35人阅读

CREATE TABLE student_to_teacher (
    id int NOT NULL UNIQUE AUTO_INCREMENT, 
    student_id int, 
    teacher_id int, 
    PRIMARY KEY (student_id, teacher_id)
);

DESC student_to_teacher;
+------------+---------+------+-----+---------+----------------+
| Field      | Type    | Null | Key | Default | Extra          |
+------------+---------+------+-----+---------+----------------+
| id         | int(11) | NO   | UNI | NULL    | auto_increment |
| student_id | int(11) | NO   | PRI | NULL    |                |
| teacher_id | int(11) | NO   | PRI | NULL    |                |
+------------+---------+------+-----+---------+----------------+
3 rows in set (0.05 sec)
技术分享

 

 

索引

索引在MySQL中也叫做“键”,是存储引擎用于快速找到记录的一种数据结构。索引对于良好的性能非常关键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要。

索引优化应该是对查询性能优化最有效的手段了。
索引能够轻易将查询性能提高好几个数量级。
索引相当于字典的音序表,如果要查某个字,如果不使用音序表,则需要从几百页中逐页去查。

索引特点:创建与维护索引会消耗很多时间与磁盘空间,但查询速度大大提高!

创建索引时候会用到一系列算法,如hash、二叉树、红黑树等

创建索引

INDEX和KEY都是索引

语法:

CREATE TABLE 表名 (
             字段名1  数据类型 [完整性约束条件…],
             字段名2  数据类型 [完整性约束条件…],
             [UNIQUE]   INDEX | KEY
             [索引名]  (字段名[(长度)]  [ASC |DESC])
);

 

 示例:

技术分享
--创建普通索引示例:

    CREATE TABLE emp1 (
        id INT,
        name VARCHAR(30) ,
        resume VARCHAR(50),
        INDEX index_emp_name (name)
    --KEY index_dept_name (dept_name)
        );


--创建唯一索引示例:

    CREATE TABLE emp2 (
        id INT,
        name VARCHAR(30) ,
        bank_num CHAR(18) UNIQUE ,
        resume VARCHAR(50),
        UNIQUE INDEX index_emp_name (name)
        );

--创建全文索引示例:

    CREATE TABLE emp3 (
        id INT,
        name VARCHAR(30) ,
        resume VARCHAR(50),
        FULLTEXT INDEX index_resume (resume)
        );

--创建多列索引示例:

    CREATE TABLE emp4 (
        id INT,
        name VARCHAR(30) ,
        resume VARCHAR(50),
        INDEX index_name_resume (name,resume)
        );
技术分享

 

练习:

技术分享
--创建表
create table Indexdb.t1(id int,name varchar(20));


--存储过程

delimiter $$
create procedure autoinsert() 
BEGIN
declare i int default 1;
while(i<500000)do
insert into Indexdb.t1 values(i,‘yuan‘);
set i=i+1;
end while;
END$$

delimiter ;

--调用函数
call autoinsert();

-- 花费时间比较:
-- 创建索引前
   select * from Indexdb.t1 where id=300000;--0.32s
-- 添加索引 
   create index index_id on Indexdb.t1(id);
-- 创建索引后
   select * from Indexdb.t1 where id=300000;--0.00s
技术分享

Linux-数据库4

标签:后缀名   0.00   esc   记录   sam   函数   内存   mysqld   分发   

人气教程排行