交流群:462197261站长百科站长论坛热门标签收藏本站北冥有鱼 互联网前沿资源第一站 助力全行业互联网+
点击这里给我发消息
  • 当前位置:
  • 浅析mysql索引

    数据库索引是一种数据结构,目的是提高表的操作速度。可以使用一个或多个列,提供快速随机查找和访问记录的高效排序来创建索引。

    要创建的索引,应当认为哪列将用于使SQL查询,创建对这些列的一个或多个索引。

    实际上,索引也是表,其中保存主键或索引字段的指针并指向每个记录到实际的表的类型。

    用户无法看到索引,它们只是用来加速查询,并将被用于数据库搜索引擎在查找记录时提高速度。

    INSERT和UPDATE语句需要更多的时间来创建索引,作为在SELECT语句快速在这些表上操作。其原因是,在执行插入或更新数据时,数据库需要将插入或更新索引值也更新。

    简单和唯一索引

    可以在表上创建唯一值索引。唯一索引意味着两行不能有相同的索引值。下面是在表上创建索引的语法:

    CREATE UNIQUE INDEX index_name
    ON table_name ( column1, column2,...);

    可以使用一个或多个列来创建索引。例如,我们可以使用tutorial_author 来创建一个 tutorials_tbl 索引。

    CREATE UNIQUE INDEX AUTHOR_INDEX
    ON tutorials_tbl (tutorial_author)

    可以在表上创建一个简单的索引。创建简单的索引只是省略UNIQUE关键字。简单的索引可以在表中重复的值。

    如果想索引的列的值按降序排列,可以列名之后添加保留字DESC。

    mysql> CREATE UNIQUE INDEX AUTHOR_INDEX
    ON tutorials_tbl (tutorial_author DESC)

    使用ALTER命令来添加和删除索引

    有四种类型的索引可以添加到一个表:

    • ALTER TABLE tbl_name ADD PRIMARY KEY (column_list):  添加一个主键(PRIMARY KEY),这意味着索引值必须是唯一的,而不能为空。
    • ALTER TABLE tbl_name ADD UNIQUE index_name (column_list):  创建一个索引的量的值必须是唯一的(除了不能使用NULL值,其它的可以出现多次)。
    • ALTER TABLE tbl_name ADD INDEX index_name (column_list):  增加普通的索引,其中的任何值的出现多次。
    • ALTER TABLE tbl_name ADD FULLTEXT index_name (column_list): 创建一个用于文本搜索目的一种特殊的FULLTEXT索引。

    下面是一个添加索引到现有表的例子。

    mysql> ALTER TABLE testalter_tbl ADD INDEX (c);

    可以通过使用 ALTER 命令以及DROP子句来删除索引。试试下面的例子,用来删除上面创建的索引。

    mysql> ALTER TABLE testalter_tbl DROP INDEX (c);

    使用ALTER命令来添加和删除PRIMARY KEY

    也可以用同样的方法添加主键。但要在列确保主键正常使用,需要指定使用 NOT NULL。

    下面是一个例子添加主键在现有的表。列需要添加 NOT NULL 属性,然后再添加为一个主键。

    mysql> ALTER TABLE testalter_tbl MODIFY i INT NOT NULL;
    mysql> ALTER TABLE testalter_tbl ADD PRIMARY KEY (i);

    可以使用ALTER命令删除主键如下:

    mysql> ALTER TABLE testalter_tbl DROP PRIMARY KEY;

    要删除索引的不是主键,必须指定索引名。

    显示索引信息

    可以使用SHOW INDEX命令,列出所有与表相关的索引。 垂直格式输出(由\G指定),这是经常有用的语句,以避免长线概括输出:

    试试下面的例子:

    mysql> SHOW INDEX FROM table_name\G
    ........

    总结

    以上所述是小编给大家介绍的mysql索引,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对北冥有鱼网站的支持!


    广而告之:
    热门推荐:
    JS中通过url动态获取图片大小的方法小结(两种方法)

    很多时候再项目中,我们往往需要先获取图片的大小再加载图片,但是某些特定场景,如用过cocos2d-js的人都知道,在它那里只能按比例缩放大小,是无法设置指定大小的图片的,这就是cocos2d-js 的坑了,我们必须先获取图片大小,计算比例再对图片进行缩放。 查阅资料,我总结了两···

    JavaScript实现在页面间传值的方法

    本文实例讲述了JavaScript实现在页面间传值的方法。分享给大家供大家参考。具体如下: 问题如下: 在 a.html 页面中,<form> 的 onsubmit 事件调用一个方法 foo( ),打开 b.html 页面的同时给 b.html 传递参数。方法 foo( ) 中需要传递变量参数到 b.html 页面,在 b.html···

    使用jQuery UI的tooltip函数修饰title属性的气泡悬浮框

    使用jQuery UI的tooltip()函数,可以使悬浮提示框不再那么千篇一律。点击这里先看看效果吧:http://www.keleyi.com/keleyi/phtml/tooltip/ 以下是完整代码:保存到html文件打开也可以看效果。 复制代码 代码如下: <!doctype html> <html> <head> <m···

    js将json格式的对象拼接成复杂的url参数方法

    var parseParam=function(param, key){ varparamStr=""; if(paraminstanceof String||param instanceof Number||param instanceof Boolean){ paramStr+="&"+key+"="+encodeURIComponent(param); }else{ $.each(param,function(i){ vark=k···

    详解FireFox下Canvas使用图像合成绘制SVG的Bug

    本文适合适合对canvas绘制、图形学、前端可视化感兴趣的读者阅读。 楔子 所有的事情都会有一个起因。 最近产品上需要做一个这样的功能:给一些图形进行染色处理。想想这还不是顺手拈来的事情,早就研究过图形染色的技术。于是我把之前写好的两种算法发给了小伙伴,让他参照实现···

    基于jQuery的JavaScript模版引擎JsRender使用指南

    前言      JsRender是一款基于jQuery的JavaScript模版引擎,它具有如下特点:           ·  简单直观           ·  功能强大    &n···

    php使用curl出现Expect:100-continue解决方法

    本文实例讲述了php使用curl出现Expect:100-continue解决方法。分享给大家供大家参考。具体如下: 使用curl POST数据时,如果POST的数据大于1024字节,curl并不会直接就发起POST请求。而是会分两步。 1.发送一个请求,header中包含一个Expect:100-continue,询问Server是否愿意···

    最佳的addEvent事件绑定是怎样诞生的

    当我们编写脚本的时候创建了交叉引用,例如如下代码: window.onload = function() { var x = document.getElementsByTagName('H3'); for (var i = 0; i < x.length; i++) { x[i].onclick = openClose; x[i].relatedElement = x[i].nextSibling; // simplifi···

    JS实现的base64加密解密完整实例

    本文实例讲述了JS实现的base64加密解密。分享给大家供大家参考,具体如下: 完整的代码: <HTML> <HEAD> <TITLE>Base64</TITLE> <script language=javascript> var base64EncodeChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz···

    帝国模板后台上传60几M的文件怎么不行呢

    上传60几M的文件怎么不行呢? 没有提示 只显示:无法显示该页 10M的文件也上传不了 后台上传附件大小我已改成100M了 修改php配置文件php.ini: upload_max_filesize 单文件最大上传大小 post_max_size 表单最大上传大小 同时还需重启APACHE。