mysql hint 驱动_(1.11)SQL优化——mysql提示(hint)

本文介绍了MySQL查询优化的各种技巧,包括如何使用SQL提示如FORCE INDEX、IGNORE INDEX等来控制索引的使用,以及如何通过HIGH_PRIORITY、LOW_PRIORITY等关键字来调整查询的优先级。此外还涉及了SQL缓存控制和延时插入等高级特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

(1.11)mysql hint

关键词:mysql提示

1、SQL提示 (hint)是优化数据库的手段之一,使用它加入一些人为的提示来达到优化操作的目的;

举例:  select sql_buffer_result * from ......

这个语句强制Mysql生成一个临时结果集。只要临时结果集生成后,所有表上的锁定均被释放;

2、常用提示

【2.1】 use index :建议使用索引(根据CBO可能仍然不会使用该索引)

添加此项来提供希望mysql去参考的索引列表,可以让mysql不再考虑其他可用索引

举例: select count(*) from tab use index (idx_id);

【2.2】ignore index :忽略索引

添加此项,只是单纯的想让mysql忽略一个或多个索引。

举例: select count(*) from tab ignore index (idx_id);

【2.3】force index:强制使用索引

添加此项,mysql必定会强制走该索引的扫描,即使该方式比全表扫效率更低!

select count(*) from tab force index (idx_id) where id>1;

【2.4】更全面的常用hint

mysql常用的hint

[b]强制索引 FORCE INDEX[/b]

SELECT * FROM TABLE1 FORCE INDEX (FIELD1) …

以上的SQL语句只使用建立在FIELD1上的索引,而不使用其它字段上的索引。

[b]忽略索引 IGNORE INDEX[/b]

SELECT * FROM TABLE1 IGNORE INDEX (FIELD1, FIELD2) …

在上面的SQL语句中,TABLE1表中FIELD1和FIELD2上的索引不被使用。

[b]关闭查询缓冲 SQL_NO_CACHE[/b]

SELECT SQL_NO_CACHE field1, field2 FROM TABLE1;

有一些SQL语句需要实时地查询数据,或者并不经常使用(可能一天就执行一两次),这样就需要把缓冲关了,不管这条SQL语句是否被执行过,服务器都不会在缓冲区中查找,每次都会执行它。

[b]强制查询缓冲 SQL_CACHE[/b]

SELECT SQL_CALHE * FROM TABLE1;

如果在my.ini中的query_cache_type设成2,这样只有在使用了SQL_CACHE后,才使用查询缓冲。

[b]优先操作 HIGH_PRIORITY[/b]

HIGH_PRIORITY可以使用在select和insert操作中,让MYSQL知道,这个操作优先进行。

SELECT HIGH_PRIORITY * FROM TABLE1;

[b]滞后操作 LOW_PRIORITY[/b]

LOW_PRIORITY可以使用在insert和update操作中,让mysql知道,这个操作滞后。

update LOW_PRIORITY table1 set field1= where field1= …

[b]延时插入 INSERT DELAYED[/b]

INSERT DELAYED INTO table1 set field1= …

INSERT DELAYED INTO,是客户端提交数据给MySQL,MySQL返回OK状态给客户端。

而这是并不是已经将数据插入表,而是存储在内存里面等待排队。当mysql有 空余时,再插入。另一个重要的好处是,来自许多客户端的插入被集中在一起,并被编写入一个块。这比执行许多独立的插入要快很多。坏处是,不能返回自动递增 的ID,以及系统崩溃时,MySQL还没有来得及插入数据的话,这些数据将会丢失。

[b]强制驱动表 STRAIGHT_JOIN

SELECT post.*

FROM post

STRAIGHT_JOIN post_tag ON post.id = post_tag.post_id

WHERE post.status = 1 AND post_tag.tag_id = 123

ORDER BY post.created DESC

LIMIT 100

使用 post_tag 为驱动表

参考:https://blog.huoding.com/2013/06/04/261

类似于这种优化器 HIT 。

并不推荐新手使用 .

除了 SQL_CACHE,SQL_NO_CACHE,SQL_BUFFER_RESULT 这种新手可以用用,

其他的类似权重调节或者是 SQL_SMALL_RESULT , SQL_BIG_RESULT 这些不推荐新手使用 . 交给优化器去做

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值