首页 > 数据库 >GreatSQL 在 SQL 中使用 HINT 语法修改会话变量

GreatSQL 在 SQL 中使用 HINT 语法修改会话变量

时间:2024-11-09 18:09:22浏览次数:3  
标签:SET HINT GreatSQL bk SQL VAR com SELECT wAP

GreatSQL 在 SQL 中使用 HINT 语法修改会话变量
在 GreatSQL 支持一种新的优化 Hint,名字叫 SET_VAR,这个特性支持用户在查询语句里修改 GreatSQL 数据库的一些会话变量,当然修改只是对当前查询会话生效,不会影响到其他会话。

SET_VAR 语法
SET_VAR 这个 hint 用于临时设置系统变量的会话值 (在单个语句的持续时间内有效)

SET_VAR 的用法: SET_VAR(var_name =value )

var_name 是被临时修改的会话变量名,value 是会话变量的取值

greatsql> SELECT @@unique_checks;SELECT /*+ SET_VAR(unique_checks=OFF) / @@unique_checks;SELECT @@unique_checks;
SELECT /
+ SET_VAR(sort_buffer_size = 16M) / name FROM people ORDER BY name;
INSERT /
+ SET_VAR(foreign_key_checks=OFF) / INTO t2 VALUES(2);
SELECT /
+ SET_VAR(optimizer_switch = 'mrr_cost_based=off') */ 1;
GreatSQL 8.0 之前的操作方法
在 GreatSQL 8.0 之前要对一个查询进行会话变量修改,需要怎么操作:

  1. 查询之前的系统变量

greatsql> SELECT @@optimizer_switch;
2. 备份系统变量

greatsql> SET @old_optimizer_switch = @@optimizer_switch;
3. 设置新的变量

greatsql> SET optimizer_switch='index_merge=off';
4. 运行查询语句

greatsql> SELECT empno,ename,deptno from emp limit 1;
5. 恢复之前的系统变量

greatsql> SET optimizer_switch = @old_optimizer_switch;
是不是有点繁琐,现在我们使用 SET_VAR 这个新特性,很方便的就可以做这个操作了。

GreatSQL 8.0 的操作方法
greatsql>explain SELECT empno,ename,deptno FROM emp WHERE deptno=10 or ename='CLARK';
+----+-------------+-------+------------+-------------+------------------+------------------+---------+------+------+----------+--------------------------------------------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+-------+------------+-------------+------------------+------------------+---------+------+------+----------+--------------------------------------------+
| 1 | SIMPLE | emp | NULL | index_merge | deptno,idx_ename | deptno,idx_ename | 5,63 | NULL | 4 | 100.00 | Using union(deptno,idx_ename); Using where |
+----+-------------+-------+------------+-------------+------------------+------------------+---------+------+------+----------+--------------------------------------------+
1 row in set, 1 warning (0.01 sec)
从执行计划上看,SQL 语句使用了索引合并(type=index_merge),如果不想该 sql 使用索引合并,则可以通过 SET_VAR 进行控制。

greatsql>explain SELECT /*+ SET_VAR(optimizer_switch='index_merge=off') */ empno,ename,deptno FROM emp WHERE deptno=10 or ename='CLARK';
+----+-------------+-------+------------+------+------------------+------+---------+------+------+----------+-------------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+-------+------------+------+------------------+------+---------+------+------+----------+-------------+
| 1 | SIMPLE | emp | NULL | ALL | deptno,idx_ename | NULL | NULL | NULL | 14 | 38.10 | Using where |
+----+-------------+-------+------------+------+------------------+------+---------+------+------+----------+-------------+
1 row in set, 1 warning (0.00 sec
这个新特性是不是很方便呢,之前由于优化器的某些设置,少量 sql 语句选择了错误的执行计划,导致查询语句性能低下,又不能随意更改线上数据库的变量,有了 SET_VAR 这个新特性,对于这种情况,可以考虑在查询语句中使用 set_var 优化这条语句。

我们知道,使用 hash jion 时,会使用到 join buffer,join buffer 的大小由 join_buffer_size 控制,其默认值为 256k,哈希连接不能使用超过此数量的内存。当哈希连接所需的内存超过可用量时,GreatSQL 将使用磁盘上的文件来处理此问题,使用到了磁盘文件,性能会下降,如果只想针对单条语句设置 join buffer 就可以使用 SET_VAR。

CREATE TABLE t1 (c1 INT, c2 INT);
CREATE TABLE t2 (c1 INT, c2 INT);
CREATE TABLE t3 (c1 INT, c2 INT);
分别对 t1,t2,t3 插入 100 万,200 万,300 万数据

greatsql> SET @@cte_max_recursion_depth = 99999999;
greatsql> INSERT INTO t1
WITH recursive t AS (
SELECT 1 AS c1 ,1 AS c2
UNION ALL
SELECT t.c1+1,t.c1*2
FROM t
WHERE t.c1 <1000000
)
SELECT * FROM t;
Query OK, 1000000 rows affected (10.63 sec)
Records: 1000000 Duplicates: 0 Warnings: 0

greatsql> SELECT @@join_buffer_size;
+--------------------+
| @@join_buffer_size |
+--------------------+
| 262144 |
+--------------------+
1 row in set (0.00 sec)

greatsql> SELECT * FROM t1
JOIN t2 ON (t1.c1 = t2.c1 AND t1.c2 < t2.c2)
JOIN t3 ON (t2.c1 = t3.c1);
Empty set (6.91 sec)

greatsql> SELECT /*+ SET_VAR(join_buffer_size=16777216) */ * FROM t1
JOIN t2 ON (t1.c1 = t2.c1 AND t1.c2 < t2.c2)
JOIN t3 ON (t2.c1 = t3.c1);
Empty set (5.87 sec)
注意事项
1、并非所有会话变量都允许与 SET_VAR 一起使用。如果设置不支持用 SET_VAR 更改的系统变量,则会出现警告。

greatsql> SELECT /*+ SET_VAR(collation_server = 'utf8mb4') */ 1;
+---+
| 1 |
+---+
| 1 |
+---+
1 row in set, 1 warning (0.01 sec)

greatsql> SHOW WARNINGS\G
*************************** 1. row ***************************
Level: Warning
Code: 3637
Message: Variable 'collation_server' cannot be set using SET_VAR hint.
1 row in set (0.00 sec)
2、SET_VAR 语法只允许设置单个变量,但可以给出多个提示来设置多个变量:

SELECT /*+ SET_VAR(optimizer_switch = 'mrr_cost_based=off')
SET_VAR(max_heap_table_size = 1G) */ 1;
3、如果没有这个系统变量或变量值不正确,则忽略 SET_VAR 提示并发出警告

SELECT /*+ SET_VAR(max_size = 1G) / 1;
SELECT /
+ SET_VAR(optimizer_switch = 'mrr_cost_based=yes') */ 1;
第 1 条语句没有 max_size 这个变量,语句 2 的 mrr_cost_based= on 或者 off, 企图将其设置为 yes 是错误的,这两个语句的 hint 都会被忽略,并产生一个 warning。

greatsql> SELECT /*+ SET_VAR(max_size = 1G) */ 1;
+---+
| 1 |
+---+
| 1 |
+---+
1 row in set, 1 warning (0.00 sec)

greatsql> show warnings;
+---------+------+---------------------------------------------+
| Level | Code | Message |
+---------+------+---------------------------------------------+
| Warning | 3128 | Unresolved name 'max_size' for SET_VAR hint |
+---------+------+---------------------------------------------+
1 row in set (0.00 sec)

greatsql> SELECT /*+ SET_VAR(optimizer_switch = 'mrr_cost_based=yes') */ 1;
+---+
| 1 |
+---+
| 1 |
+---+
1 row in set, 1 warning (0.00 sec)

greatsql> show warnings;
+---------+------+-------------------------------------------------------------------------------+
| Level | Code | Message |
+---------+------+-------------------------------------------------------------------------------+
| Warning | 1231 | Variable 'optimizer_switch' can't be set to the value of 'mrr_cost_based=yes' |
+---------+------+-------------------------------------------------------------------------------+
1 row in set (0.00 sec)
4、SET_VAR 提示只允许在语句级别使用。如果在子查询中使用,则会被忽略并给出警告。

复制会忽略复制语句中的 SET_VAR,以避免潜在的安全问题。

SET_VAR 支持的变量
SET_VAR 只是对部分变量可以用的,整理了 GreatSQL 主要支持的变量供参考:
bk.huanbao580.com/c4FSw.wAp
bk.yjh9988.com/deyz/fX8Xw.WaP
bk.szlcdpq.com/0wSwf.Wap
bk.xintiao78.com/meyl/c5W4R.WAp
bk.hndsedu.com/fX8Xw.WaP
bk.huanbao580.com/asd7/c4FSw.wAp
bk.xintiao78.com/f8W4d.wAP
bk.kfamaw.com/c4FSw.wAp
bk.shuixitech.com/0wSwf.Wap
bk.kfamaw.com/0wSwf.Wap
bk.yjh9988.com/f8W4d.wAP
bk.shplcchina.com/c5W4R.WAp
bk.xintiao78.com/asd7/fX8Xw.WaP
bk.bjyins.com/cliq/fX8Xw.WaP
bk.szlcdpq.com/fX8Xw.WaP
bk.lovehua99.com/asd7/c5W4R.WAp
bk.chinabgroup.com/0wSwf.Wap
bk.kfamaw.com/f8W4d.wAP
bk.sdymsxfh.com/c5W4R.WAp
bk.jyh01.com/asd7/0wSwf.Wap
bk.gzysart.com/asd7/c4FSw.wAp
bk.wekochat.com/cliq/c4FSw.wAp
bk.jiaforhui.com/cliq/fX8Xw.WaP
bk.bctiantuo.com/c4FSw.wAp
bk.re-shake.com/c5W4R.WAp
bk.tanjiuspace.com/jasl/c4FSw.wAp
bk.zcyxsm.com/asd7/c5W4R.WAp
bk.qcbysq.com/asd7/fX8Xw.WaP
bk.cdkenxb120.com/dcwl/fX8Xw.WaP
bk.bjyins.com/dcwl/f8W4d.wAP
bk.qcbysq.com/cliq/f8W4d.wAP
bk.jiaforhui.com/jasl/0wSwf.Wap
bk.vwotech.com/jasl/c4FSw.wAp
bk.cdkenxb120.com/0wSwf.Wap
bk.zcyxsm.com/asd7/fX8Xw.WaP
bk.jinduoceramics.com/meyl/c5W4R.WAp
bk.gzysart.com/dcwl/D30eq.wAP
bk.vwotech.com/dcwl/c4FSw.wAp
bk.zcyxsm.com/jasl/f8W4d.wAP
bk.gzysart.com/asd7/0wSwf.Wap
bk.bctiantuo.com/dcwl/D30eq.wAP
bk.bctiantuo.com/c4FSw.wAp
bk.hndsedu.com/deyz/c4FSw.wAp
bk.bctiantuo.com/cliq/c5W4R.WAp
bk.kfamaw.com/jasl/0wSwf.Wap
bk.szlcdpq.com/dcwl/f8W4d.wAP
bk.wekochat.com/fX8Xw.WaP
bk.re-shake.com/dcwl/f8W4d.wAP
bk.51jyo.com/fX8Xw.WaP
bk.shuixitech.com/meyl/fX8Xw.WaP
bk.cdkenxb120.com/asd7/c5W4R.WAp
bk.chinabgroup.com/asd7/D30eq.wAP
bk.shuixitech.com/asd7/c5W4R.WAp
bk.lovehua99.com/jasl/f8W4d.wAP
bk.vwotech.com/meyl/fX8Xw.WaP
bk.testoppo.com/beyn/c5W4R.WAp
bk.huaxinlighting.com/fX8Xw.WaP
bk.gzysart.com/c4FSw.wAp
bk.lovehua99.com/deyz/f8W4d.wAP
bk.szlcdpq.com/D30eq.wAP
bk.jiaforhui.com/beyn/D30eq.wAP
bk.sdymsxfh.com/f8W4d.wAP
bk.wekochat.com/cliq/fX8Xw.WaP
bk.51jyo.com/deyz/c4FSw.wAp
bk.shuixitech.com/beyn/f8W4d.wAP
bk.lovehua99.com/deyz/c5W4R.WAp
bk.cdkenxb120.com/c4FSw.wAp
bk.tanjiuspace.com/0wSwf.Wap
bk.vwotech.com/cliq/0wSwf.Wap
bk.gzysart.com/c4FSw.wAp
bk.qcbysq.com/jasl/f8W4d.wAP
bk.jyh01.com/cliq/0wSwf.Wap
bk.jyh01.com/dcwl/f8W4d.wAP
bk.kfamaw.com/meyl/fX8Xw.WaP
bk.huaxinlighting.com/meyl/0wSwf.Wap
bk.huanbao580.com/dcwl/c4FSw.wAp
bk.huaxinlighting.com/meyl/fX8Xw.WaP
bk.cdkenxb120.com/meyl/c5W4R.WAp
bk.sdymsxfh.com/jasl/D30eq.wAP
bk.62nsfs.com/fX8Xw.WaP
bk.qcbysq.com/jasl/fX8Xw.WaP
bk.huanbao580.com/deyz/c4FSw.wAp
bk.vwotech.com/deyz/0wSwf.Wap
bk.tanjiuspace.com/f8W4d.wAP
bk.tanjiuspace.com/dcwl/c4FSw.wAp
bk.xintiao78.com/dcwl/f8W4d.wAP
bk.51jyo.com/fX8Xw.WaP
bk.wekochat.com/asd7/D30eq.wAP
bk.tanjiuspace.com/jasl/c5W4R.WAp
bk.yjh9988.com/D30eq.wAP
bk.shuixitech.com/cliq/D30eq.wAP
bk.jyh01.com/fX8Xw.WaP
bk.hndsedu.com/D30eq.wAP
bk.jinduoceramics.com/meyl/D30eq.wAP
bk.tanjiuspace.com/meyl/c4FSw.wAp
bk.vwotech.com/beyn/f8W4d.wAP
bk.tanjiuspace.com/dcwl/f8W4d.wAP
bk.cdkenxb120.com/jasl/D30eq.wAP
bk.huaxinlighting.com/cliq/c5W4R.WAp
bk.kfamaw.com/cliq/c5W4R.WAp
bulk_insert_buffer_size
default_table_encryption
default_tmp_storage_engine
div_precision_increment
end_markers_in_json
eq_range_index_dive_limit
foreign_key_checks
group_concat_max_len
internal_tmp_mem_storage_engine
join_buffer_size
lock_wait_timeout
max_error_count
max_execution_time
max_heap_table_size
max_join_size
max_length_for_sort_data
max_points_in_geometry
max_seeks_for_key
max_sort_length
optimizer_prune_level
optimizer_search_depth
optimizer_switch
optimizer_trace_max_mem_size
range_alloc_block_size
read_buffer_size
read_rnd_buffer_size
secondary_engine_cost_threshold
select_into_buffer_size
select_into_disk_sync
select_into_disk_sync_delay
show_create_table_skip_secondary_engine
sort_buffer_size
sql_auto_is_null
sql_big_selects
sql_buffer_result
sql_mode
sql_require_primary_key
sql_safe_updates
sql_select_limit
time_zone (≥ 8.0.17)
timestamp
tmp_table_size
unique_checks
updatable_views_with_limit
use_secondary_engine
windowing_use_high_precision

标签:SET,HINT,GreatSQL,bk,SQL,VAR,com,SELECT,wAP
From: https://www.cnblogs.com/XX-SHE/p/18537067

相关文章

  • MySQL 8.0 执行 COUNT () 很慢原因分析
    MySQL8.0执行COUNT()很慢原因分析1.1问题描述线上MySQL8.0.32环境在执行SELECTCOUNT(1)FROMt0获取表行数很慢,同样场景下该SQL在MySQL5.7环境很快就能拿到结果1.2问题复现测试版本:8.0.25MySQLCommunityServer-GPL和5.7.21-logMySQLCommunityServe......
  • Oracle 与 GreatSQL 差异:更改唯一索引列
    Oracle与GreatSQL差异:更改唯一索引列问题来源在从Oracle迁移到GreatSQL的应用系统中,一条普通的update语句在GreatSQL中却报错,需要进行SQL语句的改写。把实际问题简化为下面简单情况进行说明。在Oracle下,可以正常执行的update语句。--建表CREATETABLEte......
  • SQL Server Management Studio闪退,以及低版本还原高版本数据库
    求助这是我现有的SSMS版本安装了2019的和2022的SQL数据库2019的数据库,生成脚本时一切正常2022的数据库,生成脚本时闪退这个解决办法是安装高版本的SSMS吗?因为我需要低版本还原高版本数据库因为项目上买的是2022的数据库,我本地有2019和2022的,要把数据库发给同事,他的版......
  • DBeaver如何一次性执行多条sql语句,原来和单条不一样!
    前言我之前一直是用Navicat来连接数据库的,说实话,用起来真的很舒服。但是,后来,我离职了,换了一家新公司。新公司有一个规定,不准使用Navicat,其中的原因众所周知。由于Navicat是付费的,而公司又不想付这笔钱。而且,也不能使用破解的。于是,公司给我们推荐了DBeaver这款连接工具。好吧,有......
  • MySQL快速入门,一篇搞定
    MySQL1.初识MySQL1.1.为什么学数据库数据库几乎是软件体系中最核心的一个存在1.2.什么是数据库数据库(Database,简称DB)概念:长期存放在计算机内,有组织,可共享的大量数据的集合,是一个数据"仓库"作用:保存,并能安全管理数据(如:增删改查等),减少冗余...数据库总览:关......
  • 【漏洞复现】通天星CMSV6车载定位监控平台 disable SQL注入
    免责声明:        本文旨在提供有关特定漏洞的信息,以帮助用户了解潜在风险。发布此信息旨在促进网络安全意识和技术进步,并非出于恶意。读者应理解,利用本文提到的漏洞或进行相关测试可能违反法律或服务协议。未经授权访问系统、网络或应用程序可能导致法律责任或严......
  • mysql 查询月份数据.
    //查看本月数据SELECT*FROMcontent_publishWHEREdate_format(publish_time,'%Y%m')=date_format(DATE_SUB(curdate(),INTERVAL0MONTH),'%Y%m') //查看上个月数据SELECT*FROMcontent_publishWHEREdate_format(publish_time,'%Y%m')=date_for......
  • 【数据库系统概论】第3章 SQL(二)数据更新
    目录插入数据Insert1. 插入记录【插入元组】2.插入子查询结果修改数据Update1.修改某一个元组的值2.修改多个元组的值3.带子查询的修改语句删除数据 delete1.删除某一个元组的值2.删除多个元组的值 3.带子查询的删除语句插入数据Insert Insert语句用来......
  • 直播短视频系统,Mysql执行顺序代码解析
    直播短视频系统,Mysql执行顺序代码解析MySQL执行顺序FROM<left_table>ON<join_condition><join_type>JOIN<right_table>WHERE<where_condition>GROUPBY<group_by_list>HAVING<having_condition>SELECTDISTINCT<select_list&......
  • SQL语句的基本理解与应用
        首先借用Freesql的官方文档中的一段复杂代码举例,说明SQL语句的基本使用并最终实现读懂下列的复杂代码INSERTINTO[Role]([Name])OUTPUTINSERTED.[Id]as[Id],INSERTED.[Name]as[Name]VALUES(N'role1'),(N'role2')INSERTINTO[User]([Name])OUTPUTINS......