索引的作用就是快速找出在一个列上用一特定值的行。如果没有索引,MySQL不得不首先以第一条记录开始并然后读完整个表直到它找出相关的行。

索引的类型:

先写一个建表语句:

CREATE TABLE `t_order` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT 'id',
  `order_no` varchar(20) NOT NULL COMMENT '订单编号',
  `ibank_order_no` varchar(22) DEFAULT NULL COMMENT '银码头订单号',
  `user_id` varchar(16) NOT NULL COMMENT '用户id',
  `member_id` varchar(16) DEFAULT NULL COMMENT '会员id',
  `member_fee` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '会员费',
  `member_type` varchar(10) DEFAULT NULL COMMENT '会员类型',
  `channel` int(4) NOT NULL DEFAULT '0' COMMENT '用户渠道(0 侬要贷 1银码头)',
  `loan_purpose` varchar(36) NOT NULL COMMENT '借款用途',
  `loan_amount` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '借款金额',
  `borrow_time` tinyint(4) NOT NULL DEFAULT '0' COMMENT '借款时长',
  `borrow_periods` tinyint(4) NOT NULL DEFAULT '1' COMMENT '借款期数',
  `real_loan_amount` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '实际借款金额',
  `repay_total_amount` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '应还款总金额',
  `interest` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '利息',
  `annualized_rate` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '年化利率',
  `synthetical_fee` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '综合费用',
  `bank_account` varchar(30) NOT NULL DEFAULT '' COMMENT '打款银行卡号',
  `bank_name` varchar(20) NOT NULL DEFAULT '' COMMENT '打款银行名称',
  `order_status` smallint(6) NOT NULL DEFAULT '10' COMMENT '订单状态 审核中/审核完成/待放款/放款失败/已放款',
  `audit_status` varchar(10) NOT NULL DEFAULT '0' COMMENT '审核结果:1通过0拒绝',
  `who_audit` int(4) NOT NULL DEFAULT '0' COMMENT '机审还是人审(0:机审|1:人审)',
  `audit_reason` varchar(255) NOT NULL DEFAULT '' COMMENT '详细原因码表',
  `loan_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '借款时间',
  `pay_time` datetime DEFAULT NULL COMMENT '放款时间',
  `promise_repayment_time` datetime DEFAULT NULL COMMENT '约定还款时间',
  `fund_code` varchar(10) NOT NULL DEFAULT '' COMMENT '资金渠道',
  `business` varchar(36) NOT NULL DEFAULT 'nyd' COMMENT '会员使用业务范围',
  `test_status` tinyint(4) NOT NULL DEFAULT '1' COMMENT '是否测试申请 0:是;1:不是',
  `delete_flag` tinyint(4) NOT NULL DEFAULT '0' COMMENT '是否已删除 0:正常;1:已删除',
  `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '添加时间',
  `update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',
  `update_by` varchar(36) NOT NULL DEFAULT 'sys' COMMENT '最后修改人',
  `fail_type` tinyint(2) NOT NULL DEFAULT '0' COMMENT '放款失败类型 0:默认值 1:系统放款失败 2:前端手工取消放款',
  `pay_fail_reason` varchar(300) DEFAULT NULL COMMENT '放款失败原因',
  PRIMARY KEY (`id`),
  UNIQUE KEY `order_no` (`order_no`),
  KEY `idx_user_id` (`user_id`),
  KEY `idx_status` (`order_status`),
  KEY `ix_create_time` (`create_time`),
  KEY `create_time` (`create_time`),
  KEY `update_time` (`update_time`),
  KEY `ibank_order_no` (`ibank_order_no`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='订单信息表';

1.常规索引

index或key,就是所谓的常规索引,也叫作普通索引。

2.  主键索引

主键索引(Primary Key),也简称主键。它可以提高查询效率,并提供唯一性约束。一张表中只能有一个主键。

3.唯一索引

唯一索引(Unique Key),可以提高查询效率,并提供唯一性约束。一张表中可以有多个唯一索引。

4.全文索引

全文索引(Full Text),可以提高全文搜索的查询效率,一般使用Sphinx替代。但Sphinx不支持中文检索,Coreseek是支持中文的全文检索引擎,也称作具有中文分词功能的Sphinx。实际项目中,我们用到的是Coreseek。

5.外键索引

外键索引(Foreign Key),简称外键,它可以提高查询效率,外键会自动和对应的其他表的主键关联。外键的主要作用是保证记录的一致性和完整性。

MySQL数据库---索引的更多相关文章

  1. MySQL数据库索引的4大类型以及相关的索引创建

    以下的文章主要介绍的是MySQL数据库索引类型,其中包括普通索引,唯一索引,主键索引与主键索引,以及对这些索引的实际应用或是创建有一个详细介绍,以下就是文章的主要内容描述. (1)普通索引 这是最基本 ...

  2. (转)MySql数据库索引原理(总结性)

    本文引用文章如链接: http://www.codinglabs.org/html/theory-of-mysql-index.html#more-100 参考书籍:Mysql技术内幕 本文主要是阐述 ...

  3. 知识点:Mysql 数据库索引优化实战(4)

    知识点:Mysql 索引原理完全手册(1) 知识点:Mysql 索引原理完全手册(2) 知识点:Mysql 索引优化实战(3) 知识点:Mysql 数据库索引优化实战(4) 一:插入订单 业务逻辑:插 ...

  4. 为什么MySQL数据库索引选择使用B+树?

    在进一步分析为什么MySQL数据库索引选择使用B+树之前,我相信很多小伙伴对数据结构中的树还是有些许模糊的,因此我们由浅入深一步步探讨树的演进过程,在一步步引出B树以及为什么MySQL数据库索引选择使 ...

  5. MySQL数据库索引之B+树

    一.B+树是什么 B+ 树是一种树型数据结构,通常用于数据库和操作系统的文件系统中.B+ 树的特点是能够保持数据稳定有序,其插入与修改操作拥有较稳定的对数时间复杂度.B+ 树元素自底向上插入,这与二叉 ...

  6. 第二百八十八节,MySQL数据库-索引、limit分页、执行计划、慢日志查询

    MySQL数据库-索引.limit分页.执行计划.慢日志查询 索引,是数据库中专门用于帮助用户快速查询数据的一种数据结构.类似于字典中的目录,查找字典内容时可以根据目录查找到数据的存放位置,然后直接获 ...

  7. MYSQL数据库索引类型及使用

    MYSQL数据库索引类型包括普通索引,唯一索引,主键索引与组合索引,这里对这些索引的做一些简单描述: (1)普通索引 这是最基本的MySQL数据库索引,它没有任何限制.它有以下几种创建方式: 创建索引 ...

  8. MySQL数据库索引的底层原理(二叉树、平衡二叉树、B-Tree、B+Tree)

    1.MySQL数据库索引的底层原理 https://mp.weixin.qq.com/s/zA9KvCkkte2mTWTcDv7hUg

  9. MySQL数据库索引常见问题

    笔者看过很多数据库相关方面的面试题,但大多数答案都不太准确,因此决定在自己blog进行一个总结. Q1:数据库有哪些索引?优缺点是什么? 1.B树索引:大多数数据库采用的索引(innoDB采用的是b+ ...

  10. 谈谈MySQL数据库索引

    在分析MySQL数据库索引之前,很多小伙伴对数据结构中的树理解不够深刻.因此我们由浅入深一步步探讨树的演进过程,再一步步引出MySQL数据库索引底层数据结构. 一.二叉树 二叉查找树也称为有序二叉查找 ...

随机推荐

  1. 黑马学习SpringMVC 基本开发步骤

  2. Centos 自动更新git

    首先,要先配置好自己的Git,然后在某一处进行脚本的编写. 比如项目目录为:/home/project,那参考如下来进行 vim /home/project/automatic_git.sh #/bi ...

  3. jquery扩展方法详解

    http://www.jb51.net/article/51079.htm https://www.cnblogs.com/xuxiuyu/p/5989743.html     ---更详细

  4. Windows7&IIS7.5部署Discuz全攻略

    组长说在内网部署一个论坛,这可难不倒我,装个Discuz嘛.部署环境就一台普通的PC,四核i3,Windows7.这就开搞了. 准备工作 系统是Windows 7 专业版,自带IIS7.5(家庭版不带 ...

  5. 点权生成树(gentree)

    点权生成树(gentree) 题目背景 Awson是某国际学校信竞组的一只菜鸡.终于弄明白边权最小生成树后,然而又被大神嘲笑了.大神深邃的眼光中透露了些睿智,说道:“你会求点权最小生成树么?”Awso ...

  6. webpack.config.js====webpack-dev-server开发服务器配置

    1. 安装webpack-dev-server(在指定目录下),一定要先安装完毕webpack webpack-cli之后在安装webpack-dev-server 一个基于expressjs的开发服 ...

  7. Kendo UI Widgets 概述

    UI Widgets 概述 Kendo UI 是基于 jQuery 库开发的,Kendo UI widgets 是以 jQuery 插件形式提供的.这些插件的名称基本上都是以 kendo 作为前缀.比 ...

  8. 零基础逆向工程23_PE结构07_重定位表_IAT表(待补充)

    重定位表 待补充 IAT表 待补充

  9. 使用SharePreferences存取数据(慕课笔记 )

    0.视频地址:http://www.imooc.com/video/3265 1.使用SharePreferences存取数据: public class MainActivity extends A ...

  10. JAVA程序员必须要学习的知识

    Java是热门的语言之一,TIOBE编程语排名Java排名第二,仅在C语言之后.Java可以用来开发web应用和桌面应用,更重要的是Java具有跨平台性:write once, run everywh ...