MySQL 索引 笔记

清除表中的记录
方法一:DELETE
DELETE 不加WHERE条件,清空所有表记录。但是DELETE不会清零AUTO_INCREMENT 值
语法: delete from items;
方法二:truncate
删除表的所有记录,并清零auto_increment 值。新插入的记录从1开始。
语法: truncate table name;
索引介绍
索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针。更通俗的说,数据库索引好比是一本书前面的目录,能加快数据库的查询速度。
优点:加快搜索速度,减少查询时间 。
缺点:
1 索引是以文件存储的。如果索引过多,占磁盘空间较大。而且他影响: insert ,update ,delete 执行时间。
2索引中数据必须与数据表数据同步:如果索引过多,当表中数据更新的时候,索引也要同步更新,这就降低了insert、update、delete的效率。
索引类型:
普通索引
create table 表名( 列定义…… , index 索引名称 (字段), index 索引名称 (字段));

唯一性索引

create table 表名( 列定义, unique key 索引名1(字段), unique key 索引名2(字段));
普通索引基本相同,但有一个区别:索引列的所有值都只能出现一次,即必须唯一,不能有重复的值,用来约束内容。唯一性允许有NULL值。

主键索引

设置主键就会在该列上自动创建主键索引,每个表最多只能有一个主键。主键列要求列的所有内容必须唯一。主键索引是一种特殊的唯一索引, 但不允许有空值。
创建主键索引
create table demo5( id int(4) not null auto_increment primary key, name varchar(20) default null);

复合索引
索引可以包含一个、两个或更多个列。两个或更多个列上的索引被称作复合索引
例: 创建一个表,存放服务器允许或拒绝的IP和port,要数值中IP和port字段唯一。
create table firewall ( host varchar(15) not null ,port smallint(4) not null ,access enum(‘deny’,‘allow’) not null, primary key (host,port)); #复合主键

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值