这个选项,对 SQL 执行的影响有多大呢?在查询一个 6kw 行的表时,影响巨大,带上 quick 后,性能提升 5 倍:
[root@localhost] time obclient --prompt "OceanBase(\u@\d)>" --quick -h 127.0.0.1 -P 2828 -utest -DTEST -e "select * from lineitem" > /dev/null
real 3m50.024s
user 2m35.192s
sys 0m21.271s
[root@localhost] time obclient --prompt "OceanBase(\u@\d)>" -h 127.0.0.1 -P 2828 -utest -DTEST -e "select * from lineitem" > /dev/null
real 20m19.270s
user 20m2.626s
sys 0m17.645s
quick 背后是什么呢?
通过 mysql.cc 的源码可以一窥本质:
·{“quick”, ‘q’,
"Don’t cache result, print it row by row. This may slow down the server "
“if the output is suspended. Doesn’t use history file.”,

这个 store_result 呢,它会一次性把服务器的数据缓存到本地,然后再输出到外部,是个阻塞接口,非常影响性能。

1615

被折叠的 条评论
为什么被折叠?



