第一步,创建数据库表t_tree_info,命令如下:
create table t_tree_info(
id int(8),
tno int(4),
tname varchar(20),
tdesc varchar(100)
);
如下图所示:
第二步,向表里插入3条数据,插入后查看表记录,如下图所示:
第三步,创建数据库索引tree_name,命令如下:
create index tree_name on t_tree_info (tname(20));
如下图所示:
第四步,查看数据库表索引,利用show命令
show index from t_tree_info;
如下图所示:
第五步,重建索引,利用repari命令
repair table t_tree_info quick;
如下图所示:
第六步,索引创建好了,在不使用该索引时,可以删除
drop index tree_name on t_tree_info;
如下图所示:
必须是dba权限用进行查询,固定写法(job的是不在这个表中):
sql:select object_type,count() from dba_objects where object_type in ('PACKAGE','PROCEDURE','FUNCTION','SEQUENCE') group by object_type;
JOB不行,得查dba_jobs
sql: select count() from dba_jobs;
USE 使用的数据库
SELECT siname AS IndexName
, sitype_desc AS IndexType
, si
FROM sysindexes AS si
INNER JOIN sysobjects AS so
ON siobject_id = soobject_id
WHERE soname = '表名'
用sysindexes直接提取不好吗?
SELECT OBJECT_SCHEMA_NAME(object_id)+''+OBJECT_NAME(object_id) AS 表名,name AS 索引名
FROM sysindexes
WHERE index_id<>0 AND object_id IN(SELECT object_id FROM systables)
1、数据库索引是什么,有什么用
数据库索引是对数据库表中一列或多列的值进行排序的一种结构,使用索引可快速访问数据库表中的特定信息。如果想按特定职员的姓来查找他或她,则与在表中搜索所有的行相比,索引有助于更快地获取信息。
索引的一个主要目的就是加快检索表中数据的方法,亦即能协助信息搜索者尽快的找到符合限制条件的记录ID的辅助数据结构。
2、数据库索引的用法
当表中有大量记录时,若要对表进行查询,第一种搜索信息方式是全表搜索,是将所有记录一一取出,和查询条件进行一一对比,然后返回满足条件的记录,这样做会消耗大量数据库系统时间,并造成大量磁盘I/O *** 作;
第二种就是在表中建立索引,然后在索引中找到符合查询条件的索引值,最后通过保存在索引中的ROWID(相当于页码)快速找到表中对应的记录。
索引是一个单独的、物理的数据库结构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识值的数据页的逻辑指针清单。
扩展资料:
一、索引的原理:
对要查询的字段建立索引其实就是把该字段按照一定的方式排序;建立的索引只对该字段有用,如果查询的字段改变,那么这个索引也就无效了,比如图书馆的书是按照书名的第一个字母排序的,那么你想要找作者叫张三的就不能用改索引了;还有就是如果索引太多会降低查询的速度。
二、数据库索引的特点:
1、避免进行数据库全表的扫描,大多数情况,只需要扫描较少的索引页和数据页,而不是查询所有数据页。而且对于非聚集索引,有时不需要访问数据页即可得到数据。
2、聚集索引可以避免数据插入 *** 作,集中于表的最后一个数据页面。
3、在某些情况下,索引可以避免排序 *** 作。
参考资料:
以上就是关于如何利用MySQL命令创建,查看,重建和删除索引全部的内容,包括:如何利用MySQL命令创建,查看,重建和删除索引、查询出oracle数据库所有的索引(存储过程,job,squeuse等) 数量、求解怎么用SQL server 查找一个数据库某个表有多少索引,分别是什么等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)