VIP用户交流群:462197261热门标签收藏本站北冥有鱼 互联网前沿资源第一站 助力全行业互联网+
在线客服:78895949
  • 当前位置:
  • 浅析mysql索引

    教程大全 2019年11月20日 关键词:,,,

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

    要创建的索引,应当认为哪列将用于使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索引,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对北冥有鱼网站的支持!


    广而告之:
    热门推荐:
    关于Zend Studio 配色方案插件的介绍

    首先,菜单栏–help–install new software… 接着,添加一个更新源,就是点击界面的add按钮,在新窗口的location位置输入http://eclipse-color-theme.github.com/update/,然后上边的Name自己随便起.然后ok. 选择你刚添加的更新源,稍等后应该能看到下边有eclipse_color_theme这···

    修改DedeCMS pagebreak标签 不列出全部页

    需求:我的图片集有几百张,幻灯显示会把所有的都列出来,影响美观,如图:         效果:     修改后达到这个效果,只列前后6张,共13个链接,如图:         方法:     修改 include\inc_archives_view.php ···

    wordpress中短代码失效解决办法

    在以前的代码中,我们仅仅使用add_shortcode函数来把短代码注册到wordpress中,在文章页使用the_content来显示文章内容,这样短代码就能显示成为我们想要的效果。但是,正如前文所述,这种方法失效了,用the_content来使短代码生效的愿望破灭,不过我们可以对此进行修改,以此···

    php gzip压缩输出的实现方法

    一、gzip介绍          gzip是GNU zip的缩写,它是一个GNU自由软件的文件压缩程序,也经常用来表示gzip这种文件格式。软件的作者是Jean-loup Gailly和Mark Adler。1992年10月31日第一次公开发布,版本号是0.1,目前的稳定版本是···

    vue实现图片滚动的示例代码(类似走马灯效果)

    上次写了一个简单的图片轮播,这个相当于在上面的一些改进。这个组件除了可以进行图片滚动外,也可以嵌入任何内容的标签进行滚动,里面用了slot进行封装。 父: <template> <div id="app"> <er-carousel-index :typeNumber=2 :pageNumber=3 :timeSpace=2 :d···

    dreamweaver怎么制作文本框? dw文本框的两种制作方法

    Dreamweaver可以很方便的制作网页,因为是可视化的,所以很适合新手。那么dreamweaver如何添加文本输入框呢? 软件名称: Adobe Dreamweaver CS6 绿色精简版 by Ansifa (2013.2.22) 93M 软件大小: 93.1MB 更新时间: 2013-09-27 首先我们建立一个空白的html,小编这里用的···

    内容页的smalltext字数控制方法

    先到参数设置开启模板支持程序代码,然后用这个显示简介: <?=sub($navinfor[smalltext],0,截取字数,false)?>

    [PHP]实用函数3

    //获得当前的脚本网址 复制代码 代码如下:function get_php_url(){          if(!empty($_server["REQUEST_URI"])){                &n···

    ThinkPHP3.2.2的插件控制器功能简述

    ThinkPHP从3.2.2版本开始支持插件控制器的调用,可以通过更加方便的URL地址访问到模块中某个插件定义的控制器。 当URL中传入插件控制器变量的时候,会自动定位到插件控制器中的操作方法。 插件控制器的变量由参数 VAR_ADDON 进行设置,默认为addon,例如我们在URL中传入: ht···

    PHP和JavaScrip分别获取关联数组的键值示例代码

    PHP版: 复制代码 代码如下: $o = array('x'=>1, 'y'=>2, 'z'=>3); $arr = array(); $i = 0; foreach( $o as $arr[$i++]=>$v )/*empty*/; var_dump($arr); //$arr = array('x', 'y', 'z'); JavaScrip版: 复制代码 代码如下: var o = {x:1, y:2, z:3}; var ···