mysql数据库优化课程---5、要索引和不要索引的区别是什么

一、总结

一句话总结:

索引速度快,就是查表的时候,操作的话设置索引就好了

1、数据库设计的时候不允许字段为null的好处是什么?

null要占4-5个字段:单为空的时候,不允许为null的话要么为0要么为空字符串,占一个字段

而null要占4-5个字段,所以用null做划不来

2、为什么数据表的外键使用的很少?

a、非常不灵活,当你想删某个字段的时候,会出现因为是外键删除报错很麻烦
b、外键的功能完全可以被连表所代替
c、和实际情况不符合:比如说一个用户最近乱发帖,你需要删了它,但是如果设置为外键,需要把用户所有的评论文章全部删掉,而这些评论文章没有必要全部删掉

所以外键这种太强制的约束用的少

3、删除主键之前的操作是什么?

先要把自增删了才能删主键,因为自增是字段属性

一个表只能有一个主键

alter table user2 modify id int unsigned not null;(删自增)
alter table user2 drop primary key;(删主键)

4、索引如何使用?

检索在查询的时候自己使用,而不需要我们做什么特别的操作来体现,我们要做的就是初期给哪些字段加上索引,加上什么索引

索引作用:检索加速

5、索引里面的唯一索引是什么?

就是数据库里面这个字段不能重复,重复就报错
添加了唯一索引,那么就可以快速检索这个字段了

1)添加
alter table user2 add unique u_username(username);

2)删除
alter table user2 drop index u_username;

6、主键索引和唯一索引的关系?

主键索引本身就包含唯一索引,所以主键索引中也不能重复,比如id,重复就报错

主键索引检索速度最快

唯一索引会比普通索引快

7、如何查看一个数据表user的字段情况?

desc user;

8、程序中的唯一索引检测出现的位置在哪(在php中检测还是在mysql中唯一索引)?

php中:是判断重复了php给出提示,而不是在mysql中唯一索引报错

应该在php中检测,而不是mysql中的唯一索引,

是判断重复了php给出提示,而不是在mysql中唯一索引报错

9、普通索引在数据库中的字段表示是什么?

普通索引:mul
主键索引:pri
唯一索引:uni

1)添加
alter table user2 add index i_username(username);

2)删除
alter table user2 drop index i_username;

10、要索引和不要索引的区别是什么?

要索引检测速度快,就是查表的时候

而不需要做什么特别操作啦体现索引

二、内容在总结中

字段管理:
1.添加字段
alter table user add age tinyint unsigned not null;
alter table user add pass varchar(30) not null after user;
alter table user add pass varchar(30) not null first;

2.删除字段
alter table user drop password;

3.修改字段
alter table user modify username varchar(30) not null;
alter table user change username user varchar(30) not null;

4.查看字段
desc user;

索引:
1.主键
1)添加
mysql> create table user2(
    -> id int unsigned not null auto_increment,
    -> username varchar(30) not null,
    -> primary key(id)
    -> );

mysql> create table user2(
    -> id int unsigned not null auto_increment primary key,
    -> username varchar(30) not null
    -> );

2)删除
alter table user2 modify id int unsigned not null;
alter table user2 drop primary key;

2.唯一
1)添加
alter table user2 add unique u_username(username);

2)删除
alter table user2 drop index u_username;

3.普通
1)添加
alter table user2 add index i_username(username);

2)删除
alter table user2 drop index i_username;

 

mysql数据库优化课程---5、要索引和不要索引的区别是什么的更多相关文章

  1. mysql数据库优化课程---17、mysql索引优化

    mysql数据库优化课程---17.mysql索引优化 一.总结 一句话总结:一些字段可能会使索引失效,比如like,or等 1.check表监测的使用场景是什么? 视图 视图建立在两个表上, 删除了 ...

  2. mysql数据库优化课程---18、mysql服务器优化

    mysql数据库优化课程---18.mysql服务器优化 一.总结 一句话总结: 1.四种字符集问题:字符集都设置为utf-82.slow log慢查询日志问题3.root密码丢失 1.mysql存在 ...

  3. mysql数据库优化课程---16、mysql慢查询和优化表空间

    mysql数据库优化课程---16.mysql慢查询和优化表空间 一.总结 一句话总结: a.慢查询的话找到存储慢查询的那个日志文件 b.优化表空间的话可以用optimize table sales; ...

  4. mysql数据库优化课程---15、mysql优化步骤

    mysql数据库优化课程---15.mysql优化步骤 一.总结 一句话总结:索引优化最立竿见影 1.mysql中最常用最立竿见影的优化是什么? 索引优化 索引优化,不然有多少行要扫描多少次,1亿行大 ...

  5. mysql数据库优化课程---13、mysql基础操作

    mysql数据库优化课程---13.mysql基础操作 一.总结 一句话总结:mysql复制表,索引,视图 1.mysql如何复制表? like select * 1.复制表结构 create tab ...

  6. mysql数据库优化课程---12、mysql嵌套和链接查询

    mysql数据库优化课程---12.mysql嵌套和链接查询 一.总结 一句话总结:查询user表中存在的所有班级的信息? in distinct mysql> select * from cl ...

  7. mysql数据库优化课程---9、php用什么写的

    mysql数据库优化课程---9.php用什么写的 一.总结 一句话总结:php是用c语言写的,所以php里面的那些模块什么都是c语言 c 1.php用什么写的? c php是用c语言写的,所以php ...

  8. mysql数据库优化课程---7、网站的搜索技术怎么选

    mysql数据库优化课程---7.网站的搜索技术怎么选 一.总结 一句话总结: 1.量很小(像小网站)---like2.量大一点()---标签3.量超级大(像百度)---搜索引擎 1.数据库中取一列比 ...

  9. mysql数据库优化课程---2、命令其实也就是那几个单词

    mysql数据库优化课程---2.命令其实也就是那几个单词 一.总结 一句话总结: 比如show,use,alter 1.开启和关闭mysql服务? Windows下:net start/stop m ...

随机推荐

  1. php-fpm 启动 关闭 进程逃逸 pid

    正常关闭失败 [root@d personas]# /etc/init.d/php-fpm stopGracefully shutting down php-fpm /etc/init.d/php-f ...

  2. docker related,docker history

    History of an image and size of layers: docker history --no-trunc=true zabbix/zabbix-3.0 | tr -s ' ' ...

  3. 【python】-- Django

    Django Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Sessio ...

  4. 修改本机域名localhost为任意你想要的名称

    web项目研发中,测试的时候项目路径与发布以后的路径不一致,项目组之间的路径不一致,这样会加大工作量,这个时候我们可以统一一下开发的路径,这样可以省很多事,话不多说,看下面教程: 在系统盘中的如下路径 ...

  5. 插叙LTE-2

      LTE TDD与LTE FDD技术简介和比较 标签: 频分双工(FDD) 时分双工(TDD) LTE 摘要:UTRA 的长期演进(Long Term Evolution ,LTE) 技术存在LTE ...

  6. setdefault函数的用法及个人理解

    setdefault函数的用法及理解 dict.setdefault(key, default=None) 功能:如果键不存在于字典中,将会添加该键并将default的值设为该键的默认值,如果键存在于 ...

  7. Linux中vim命令出现E325错误解决方法

    出现该问题的原因是: vim在编辑文件的时候会创建一个swp file来保证文件的安全性,如果没有正常退出vim的,下次打开这个文件就会报E325的错误,提示swp文件已经存在. 解决方法也简单:把这 ...

  8. [String ] StringBuffer VS StringBuilder

    StringBuilder的性能高于StringBuffer,因为StringBuffer是线程安全的. 首先说明一下,一般情况下,字符串相加默认是StringBuilder,但是当数量大于100,或 ...

  9. vim tabs

    :tabnew 增加一个标签:tabc 关闭当前的tab:tabo 关闭所有其他的tab:tabs 查看所有打开的tab:tabp 或gT 前一个:tabn 或gt 后一个:tabfirst或:tab ...

  10. gearman mysql持久化

    gearman 创建Mysql持久化队列的方式如下: 启动gearman,命令如下: gearmand命令: -b, –backlog=BACKLOG 连接请求队列的最大值 -d, –daemon D ...