还有,什么时候使用手机比较合适?
当前回答
索引用于加快在数据库中的搜索速度。MySQL有一些关于这个主题的很好的文档(也适用于其他SQL服务器): http://dev.mysql.com/doc/refman/5.0/en/mysql-indexes.html
索引可用于高效地查找查询中与某列匹配的所有行,然后仅遍历表的该子集以查找精确匹配。如果WHERE子句中的任何列上都没有索引,SQL server必须遍历整个表并检查每一行以查看是否匹配,这在大表上可能是一个缓慢的操作。
索引也可以是UNIQUE索引,这意味着在该列中不能有重复的值,也可以是PRIMARY KEY,在某些存储引擎中,PRIMARY KEY定义了值在数据库文件中的存储位置。
在MySQL中,你可以在SELECT语句前使用EXPLAIN来查看你的查询是否使用了任何索引。这是排除性能问题的良好开端。点击此处阅读更多信息: http://dev.mysql.com/doc/refman/5.0/en/explain.html
其他回答
如果你正在使用SQL Server,最好的资源之一是安装时附带的Books Online !这是第一个地方,我将参考任何SQL Server相关的主题。
如果是实际的“我应该怎么做?”之类的问题,那么StackOverflow将是一个更好的提问场所。
此外,我已经有一段时间没有回来了,但sqlservercentral.com曾经是顶级的SQL Server相关网站之一。
索引的使用有几个不同的原因。主要原因是为了加快查询速度,以便更快地获取行或对行进行排序。另一个原因是定义一个主键或唯一索引,这将保证没有其他列具有相同的值。
索引就是为了快速找到数据。
数据库中的索引类似于书籍中的索引。如果一本书有索引,我让你在书中找到一个章节,你可以在索引的帮助下很快找到。另一方面,如果这本书没有索引,你将不得不花更多的时间从开始到结束寻找每一页的章节。
以类似的方式,数据库中的索引可以帮助查询快速找到数据。如果你不熟悉索引,下面的视频会非常有用。事实上,我从他们身上学到了很多。
指数基本知识 聚集索引和非聚集索引 唯一索引和非唯一索引 指标的优缺点
索引-轻松找到数据
UNIQUE INDEX -不允许重复的值
INDEX的语法
CREATE INDEX INDEX_NAME ON TABLE_NAME(COLUMN);
UNIQUE INDEX的语法
CREATE UNIQUE INDEX INDEX_NAME ON TABLE_NAME(COLUMN);
索引是与表或视图相关联的磁盘结构,可加快从表或视图检索行的速度。索引包含从表或视图中的一个或多个列构建的键。这些键存储在一个结构(b -树)中,使SQL Server能够快速有效地查找与键值关联的行。
当在表列上定义了PRIMARY KEY和UNIQUE约束时,会自动创建索引。例如,当您创建一个带有UNIQUE约束的表时,数据库引擎会自动创建一个非聚集索引。
如果配置了PRIMARY KEY,数据库引擎将自动创建聚集索引,除非已经存在聚集索引。当您试图在现有表上强制PRIMARY KEY约束,而该表上已经存在聚集索引时,SQL Server将使用非聚集索引强制主键。
有关索引(聚集和非聚集)的更多信息,请参考此: https://learn.microsoft.com/en-us/sql/relational-databases/indexes/clustered-and-nonclustered-indexes-described?view=sql-server-ver15
希望这能有所帮助!
推荐文章
- 对于PostgreSQL表来说,多大才算太大?
- 在MySQL中检测值是否为number
- MySQL中两个日期之间的差异
- 使用SQL查询查找最近的纬度/经度
- 将一列的多个结果行连接为一列,按另一列分组
- 检查MySQL表是否存在而不使用“select from”语法?
- 在PostgreSQL中快速发现表的行数
- 更改varchar列的大小为较低的长度
- 从表中选择1是什么意思?
- SQL Server中User和Login的区别
- 如何更改表的默认排序规则?
- 为两列的组合添加唯一的约束
- 设置NOW()为datetime数据类型的默认值?
- 在MySQL中Datetime等于或大于今天
- 如何在列表中找到最大值的所有位置?