1.索引

详细介绍:http://www.cnblogs.com/57rongjielong/p/8039452.html

索引是对数据库表中一个或多个列的值进行排序的结构。索引是经过某种算法优化过的,因而查找次数相对较少。

mysql的索引分为单列索引(主键索引,唯一索引,普通索引)和组合索引.

单列索引:一个索引只包含一个列,一个表可以有多个单列索引.

组合索引:一个组合索引包含两个或两个以上的列,

2.MySQL中常见索:

A.普通索引

  1. CREATE TABLE person(
  2. pid INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
  3. pname VARCHAR(20) NOT NULL,
  4. page INT,
  5. -- 创建表时创建索引
  6. INDEX index_pname(pname)
  7. )
  8.  
  9. -- 单独创建索引
  10. -- create index 索引名称 on 表名(列名)
  11. CREATE INDEX index_page ON person(page);
  12.  
  13. -- 删除索引
  14. -- drop index 索引名称 on 表名;
  15. DROP INDEX index_page ON person;
  16.  
  17. -- 查看索引
  18. -- show index from 表名;
  19. SHOW INDEX FROM person;
  20.  
  21. -- 对于创建索引时如果是BLOB TEXT 类型,必须指定length

B.唯一索引

唯一性索引和普通索引最大的差异就是在索引列上增加了一层唯一约束。添加唯一性索引的数据列可以为空,但是只要存在数据值,就必须是唯一的。

  1. CREATE TABLE person(
  2. pid INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
  3. pname VARCHAR(20) NOT NULL,
  4. page INT,
  5. -- 创建表时创建唯一索引
  6. UNIQUE index_pname(pname)
  7. )
  8.  
  9. -- 单独创建索引
  10. -- create index 索引名称 on 表名(列名)
  11. CREATE UNIQUE INDEX index_page ON person(page);
  12.  
  13. -- 删除索引
  14. -- drop index 索引名称 on 表名;
  15. DROP INDEX index_page ON person;
  16.  
  17. -- 查看索引
  18. -- show index from 表名;
  19. SHOW INDEX FROM person;
  20.  
  21. -- 对于创建索引时如果是BLOB TEXT 类型,必须指定length

C.主键索引

在数据库关系图中为表定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型。主键索引要求主键中的每个值是唯一的。当在查询中使用主键索引时,它还允许快速访问数据。数据不能为空。

  1. CREATE TABLE person(
  2. pid INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
  3. pname VARCHAR(20) NOT NULL,
  4. page INT
  5. )

  1. CREATE TABLE person(
  2. pid INT NOT NULL AUTO_INCREMENT,
  3. pname VARCHAR(20) NOT NULL,
  4. page INT,
  5. PRIMARY KEY(pid)
  6. )
  1. CREATE TABLE person(
  2. pid INT NOT NULL,
  3. pname VARCHAR(20) NOT NULL,
  4. page INT
  5. )
  6. -- 添加主键索引
  7. ALTER TABLE person ADD PRIMARY KEY(pid);
  8. -- 删除主键
  9. ALTER TABLE person DROP PRIMARY KEY;
  10.  
  11. ALTER TABLE person MODIFY pid INT,DROP PRIMARY KEY;

D.组合索引

——两列或者多列组合成一个索引进行查询,频繁的同时使用n列来进行查询

  1. CREATE INDEX ix_pid_pname ON person(pid,pname);
  • pid and pname-- 使用索引
  • pid                   -- 使用索引
  • pname             -- 不使用索引

注意:

  • 避免使用select *
  • count(1)或count(列) 代替 count(*)
  • 创建表时尽量使用 char 代替 varchar
  • 表的字段顺序固定长度的字段优先
  • 组合索引代替多个单列索引(经常使用多个条件查询时)
  • 尽量使用短索引
  • 使用连接(JOIN)来代替子查询(Sub-Queries)
  • 连表时注意条件类型需一致
  • 索引散列值(重复少)不适合建索引,例:性别不适合

3.limit分页

  1. select * from limit 5; - 5
  2. select * from limit 4,5; - 从第4行开始的5
  3. select * from limit 5 offset 4 - 从第4行开始的5

(三)MySQL终极篇的更多相关文章

  1. Linux配置mysql (centos配置java环境 mysql配置篇 总结四)

    ♣安装的几种方法和比较 ♣配置yum源 ♣安装mysql ♣启动mysql ♣修改密码 ♣导入.sql文件 ♣缓存设置 ♣允许远程登录(navicat) ♣配置编码为utf8  1.关于Linux系统 ...

  2. 第二章 MySQL入门篇

    第一章 MySQL入门篇 一.MySql简介 简言: 和SQL Server数据库相同,MySQl也是一个关系型数据库管理系统.由瑞典的MySQL AB公司开发,2008年被SUN公司收购,2009年 ...

  3. mysql 架构篇系列 3 复制运行状态监控与选项参数说明

    一. 概述 在上一篇中,搭建了一主一从的复制架构,这篇通过一些诊断方法来了解复制的运行状态和一些选项参数说明.上次mysql主从服务关机,今天在打开mysql服务,出现了错误信息. 1.首先 启动主从 ...

  4. {MySQL数据库初识}一 数据库概述 二 MySQL介绍 三 MySQL的下载安装、简单应用及目录介绍 四 root用户密码设置及忘记密码的解决方案 五 修改字符集编码 六 初识sql语句

    MySQL数据库初识 MySQL数据库 本节目录 一 数据库概述 二 MySQL介绍 三 MySQL的下载安装.简单应用及目录介绍 四 root用户密码设置及忘记密码的解决方案 五 修改字符集编码 六 ...

  5. 【目录】mysql 进阶篇系列

    随笔分类 - mysql 进阶篇系列 mysql 开发进阶篇系列 55 权限与安全(安全事项 ) 摘要: 一. 操作系统层面安全 对于数据库来说,安全很重要,本章将从操作系统和数据库两个层面对mysq ...

  6. mysql注入篇

    博客这个东西真的很考验耐心,每写一篇笔记,都是在艰难的决定中施行的,毕竟谁都有懒惰的一面,就像这个,mysql注入篇,拖拖拖一直拖到现在才开始总结,因为这个实在是太多太杂了,细细的总结一篇太烧脑. 由 ...

  7. 最新MySQL入门篇

    一.SQL简介 ​ SQL:结构化查询语言(Structured Query Language),是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询.更新和管理关系数据库系 ...

  8. (6)MySQL进阶篇SQL优化(MyISAM表锁)

    1.MySQL锁概述 锁是计算机协调多个进程或线程并发访问某一资源的机制.在数据库中,除传统的计算资源 (如 CPU.RAM.I/O 等)的抢占以外,数据也是一种供许多用户共享的资源.如何保证数 据并 ...

  9. 「 MySQL高级篇 」MySQL索引原理,设计原则

    大家好,我是melo,一名大二后台练习生,大年初三,我又来充当反内卷第一人了!!! 专栏引言 MySQL,一个熟悉又陌生的名词,早在学习Javaweb的时候,我们就用到了MySQL数据库,在那个阶段, ...

随机推荐

  1. IOTutility 一个轻量级的 IOT 基础操作库

    IOTutility 一个轻量级的 IOT 基础操作库 Base utility for IOT devices, networking, controls etc... IOTutility 的目的 ...

  2. www.pantom.top

    新建小站 https://www.pantom.top

  3. C++ —— 非类中使用const定义常量的初始化,以及#define和typedef的区别

    总结一下在非类中使用const关键字定义常量时的初始化问题,亲测VS2015.顺便记录#define宏和typedef的区别. 1 首先对const声明的常量的初始化做简单小结: , w2 = , w ...

  4. android studio 插件开发(自动生成框架代码插件)

    android studio 插件开发 起因 去年公司开始上新项目,正好android在架构这方面的讨论也开始多了起来,于是mvp架构模型就进入我们技术选择方案里面,mvp有很多好处,但是有一个非常麻 ...

  5. 20155214 2016-2017-2 《Java程序设计》第4周学习总结

    20155214 2016-2017-2 <Java程序设计>第4周学习总结 教材学习内容总结 Chapter6 父类就是将多个类的相同代码提升(Pull Up) 子类继承父类会继承到pr ...

  6. 20155316 2016-2017-2 《Java程序设计》第10周学习总结

    教材学习内容总结 Java和Android开发学习指南(第二版)第22章 Java 密码技术 教材学习中的问题和解决过程 1.什么叫柯克霍夫原则? 数据的安全基于密钥而不是算法的保密. 也就是说系统的 ...

  7. 20155217 实验四《Java面向对象程序设计》实验报告

    20155217 实验四<Java面向对象程序设计>实验报告 一.实验内容 1.基于Android Studio开发简单的Android应用并部署测试; 2.了解Android.组件.布局 ...

  8. 20155323 第四次实验 Android程序设计实验报告

    20155323 第四次实验 Android程序设计实验报告 实验内容 1.基于Android Studio开发简单的Android应用并部署测试; 2.了解Android.组件.布局管理器的使用: ...

  9. 20155334 2016-2017-2 《Java程序设计》第十周学习总结

    20155334 2016-2017-2 <Java程序设计>第十周学习总结 教材学习内容总结 1.计算机网络概述 (1)路由器和交换机组成了核心的计算机网络,计算机只是这个网络上的节点以 ...

  10. 20145207 2016-2017-2 《Java程序设计》第4周学习总结

    一.继承与多态 1.继承的定义 面对对象中,子类继承父类,避免重复的行为定义,不过并非为了避免重复定义行为就使用继承,滥用而继承会导致程序维护上的问题. 程序代码重复在程序设计上就是不好的信号,多个类 ...