亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL 8.0.26版本升級32版本查詢數(shù)據(jù)為空的解決方案

 更新時(shí)間:2024年03月18日 09:24:35   作者:GreatSQL  
這篇文章主要介紹了MySQL 8.0.26版本升級32版本查詢數(shù)據(jù)為空的跟蹤,本文給大家分享兩種解決方法,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧

某業(yè)務(wù)系統(tǒng)將MySQL 8.0.26升級為GreatSQL 8.0.32-24 后,某些特定的SQL語句不能查詢到數(shù)據(jù)。經(jīng)測試 MySQL 8.0.32也存在相同的問題

此BUG已在 GreatSQL 8.0.32-25 版本中解決

MySQL 8.0.26版本升級32版本查詢數(shù)據(jù)為空的跟蹤

接到客戶反饋的問題后,對問題進(jìn)行了復(fù)現(xiàn)和分析。

版本信息

greatsql> select version();
+-----------+
| version() |
+-----------+
| 8.0.32-24 |
+-----------+
1 row in set (0.00 sec)

建表語句

greatsql> show create table t_student;
CREATE TABLE `t_student1` (
  `id` int NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL,
  `age` int NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;

表數(shù)據(jù)

greatsql> select * from t_student;
+----+--------+-----+
| id | name   | age |
+----+--------+-----+
|  1 | abc    |  10 |
|  2 | 湯姆   |  20 |
+----+--------+-----+
2 rows in set (0.08 sec)

查詢數(shù)據(jù)

greatsql>  select * from (select * from t_student union select * from t_student) temp where name='湯姆';
Empty set, 2 warnings (0.00 sec)
greatsql> show warnings;
+---------+------+-------------------------------------------------------------------------+
| Level   | Code | Message                                                                 |
+---------+------+-------------------------------------------------------------------------+
| Warning | 1300 | Cannot convert string '\xE6\xB1\xA4\xE5\xA7\x86' from utf8mb4 to binary |
| Warning | 1300 | Cannot convert string '\xE6\xB1\xA4\xE5\xA7\x86' from utf8mb4 to binary |
+---------+------+-------------------------------------------------------------------------+
2 rows in set (0.00 sec)
greatsql> select * from (select * from t_student union select * from t_student) temp;
+----+--------+-----+
| id | name   | age |
+----+--------+-----+
|  1 | abc    |  10 |
|  2 | 湯姆   |  20 |
+----+--------+-----+
2 rows in set (0.00 sec)
greatsql> select * from (select * from t_student union select * from t_student) temp where name='abc';
+----+------+-----+
| id | name | age |
+----+------+-----+
|  1 | abc  |  10 |
+----+------+-----+
1 row in set (0.00 sec)

可以看到 直接查詢temp這個(gè)view或者 在視圖上添加英文過濾條件均能查詢出數(shù)據(jù),在view上添加中文過濾條件sql語句返回結(jié)果為空,有warnings提醒,warnings具體內(nèi)容為Cannot convert string

在官方網(wǎng)站進(jìn)行搜索,以下連接有相似內(nèi)容:

https://bugs.mysql.com/bug.php?id=110228

https://bugs.mysql.com/bug.php?id=110955

MySQL 8.0.32版本中對于UNION/UNION ALL 后的結(jié)果中的字符串字段過濾篩選不生效,客戶端中提示:

Cannot convert string '%\x...' from utf8mb4 to binary

官方已確認(rèn)是8.0.32中的一個(gè)bug,已在8.0.33版本中修復(fù),對于8.0.32版本,官方給出的解決方式如下:

set optimizer_switch="derived_condition_pushdown=off";

讓所有Session都生效,需要在配置文件中將optimizer_switch設(shè)置為off

此BUG已在 GreatSQL 8.0.32-25 版本中解決

解決方法

方法一:

設(shè)置set optimizer_switch="derived_condition_pushdown=off";后SQL語句能正常執(zhí)行

greatsql> set optimizer_switch='derived_condition_pushdown=off';
Query OK, 0 rows affected (0.00 sec)
greatsql> select * from (select * from t_student union select * from t_student) temp where name='湯姆';
+----+--------+-----+
| id | name   | age |
+----+--------+-----+
|  2 | 湯姆   |  20 |
+----+--------+-----+
1 row in set (0.00 sec)

方法二:

對單個(gè)SQL語句設(shè)置NO_DERIVED_CONDITION_PUSHDOWN hint

greatsql> set optimizer_switch='derived_condition_pushdown=on';
Query OK, 0 rows affected (0.00 sec)
greatsql> select * from (select * from t_student union select * from t_student) temp where name='湯姆';
Empty set, 2 warnings (0.00 sec)
greatsql> select  /*+ NO_DERIVED_CONDITION_PUSHDOWN(temp) */ * from (select * from t_student union select * from t_student) temp where name='湯姆';
+----+--------+-----+
| id | name   | age |
+----+--------+-----+
|  2 | 湯姆   |  20 |
+----+--------+-----+
1 row in set (0.00 sec)

Enjoy GreatSQL ??

關(guān)于 GreatSQL

GreatSQL是適用于金融級應(yīng)用的國內(nèi)自主開源數(shù)據(jù)庫,具備高性能、高可靠、高易用性、高安全等多個(gè)核心特性,可以作為MySQL或Percona Server的可選替換,用于線上生產(chǎn)環(huán)境,且完全免費(fèi)并兼容MySQL或Percona Server。

相關(guān)鏈接: GreatSQL社區(qū) GiteeGitHubBilibili

GreatSQL社區(qū):

社區(qū)博客有獎(jiǎng)?wù)鞲逶斍椋?a rel="external nofollow" target="_blank">https://greatsql.cn/thread-100-1-1.html

到此這篇關(guān)于MySQL 8.0.26版本升級32版本查詢數(shù)據(jù)為空的跟蹤的文章就介紹到這了,更多相關(guān)mysql查詢數(shù)據(jù)為空內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL優(yōu)化之SQL調(diào)優(yōu)策略分享

    MySQL優(yōu)化之SQL調(diào)優(yōu)策略分享

    這篇文章主要介紹了MySQL優(yōu)化之SQL調(diào)優(yōu)策略,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-04-04
  • MySQL5.5.21安裝配置教程(win7)

    MySQL5.5.21安裝配置教程(win7)

    這篇文章主要以圖文結(jié)合的方式介紹了Win7系統(tǒng)下安裝MySQL5.5.21的具體過程,感興趣的小伙伴們可以參考一下
    2016-06-06
  • MySQL對數(shù)據(jù)庫數(shù)據(jù)進(jìn)行復(fù)制的基本過程詳解

    MySQL對數(shù)據(jù)庫數(shù)據(jù)進(jìn)行復(fù)制的基本過程詳解

    這篇文章主要介紹了MySQL對數(shù)據(jù)庫數(shù)據(jù)進(jìn)行復(fù)制的基本過程,解讀了Slave的一些相關(guān)配置,需要的朋友可以參考下
    2015-11-11
  • Mysql判斷表字段或索引是否存在

    Mysql判斷表字段或索引是否存在

    這篇文章主要介紹了Mysql判斷表字段或索引是否存在的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-06-06
  • 生產(chǎn)環(huán)境的MySQL事務(wù)隔離級別方式

    生產(chǎn)環(huán)境的MySQL事務(wù)隔離級別方式

    本文探討了MySQL數(shù)據(jù)庫在RR(可重復(fù)讀)和RC(讀已提交)隔離級別下的鎖機(jī)制,在RR級別下,UPDATE語句會(huì)鎖定所有符合條件的行,包括不符合條件的行,以防止幻讀,而在RC級別下,UPDATE語句僅鎖定符合條件的行,通過半一致性讀優(yōu)化,可以進(jìn)一步提高并發(fā)度
    2025-02-02
  • MySQL中多個(gè)left?join?on關(guān)聯(lián)條件的順序說明

    MySQL中多個(gè)left?join?on關(guān)聯(lián)條件的順序說明

    這篇文章主要介紹了MySQL中多個(gè)left?join?on關(guān)聯(lián)條件的順序說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 一步步教你配置MySQL遠(yuǎn)程訪問

    一步步教你配置MySQL遠(yuǎn)程訪問

    這篇文章主要給大家介紹了配置MySQL遠(yuǎn)程訪問的相關(guān)資料,文中介紹的非常詳細(xì),相信對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。
    2017-04-04
  • MySQL出現(xiàn)SQL Error (2013)連接錯(cuò)誤的解決方法

    MySQL出現(xiàn)SQL Error (2013)連接錯(cuò)誤的解決方法

    這篇文章主要介紹了MySQL出現(xiàn)SQL Error (2013)連接錯(cuò)誤的解決方法,2013錯(cuò)誤主要還是在于用戶的授權(quán)問題,需要的朋友可以參考下
    2016-06-06
  • explain命令為什么可能會(huì)修改MySQL數(shù)據(jù)

    explain命令為什么可能會(huì)修改MySQL數(shù)據(jù)

    這篇文章主要介紹了explain命令為什么可能會(huì)修改MySQL數(shù)據(jù),幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下
    2020-12-12
  • 提高M(jìn)ySQL 查詢效率的三個(gè)技巧

    提高M(jìn)ySQL 查詢效率的三個(gè)技巧

    MySQL由于它本身的小巧和操作的高效, 在數(shù)據(jù)庫應(yīng)用中越來越多的被采用.我在開發(fā)一個(gè)P2P應(yīng)用的時(shí)候曾經(jīng)使用MySQL來保存P2P節(jié)點(diǎn),由于P2P的應(yīng)用中,結(jié)點(diǎn)數(shù)動(dòng)輒上萬個(gè),而且節(jié)點(diǎn)變化頻繁,因此一定要保持查詢和插入的高效.以下是我在使用過程中做的提高效率的三個(gè)有效的嘗試. 1. 使用statement進(jìn)行綁定查詢 2. 隨機(jī)的獲取記錄 3. 使用連接池管理連接.
    2008-04-04

最新評論