欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL無(wú)法修改主鍵的問(wèn)題分析及解決方案

 更新時(shí)間:2024年01月23日 10:21:59   作者:愛可生開源社區(qū)  
最近同事咨詢了一個(gè)問(wèn)題,TDSQL(for MySQL)中的某張表主鍵需要改為聯(lián)合主鍵,是否必須先刪除現(xiàn)有的主鍵?因?yàn)閯h除主鍵時(shí),提示這個(gè)錯(cuò)誤,所以本文給大家介紹了MySQL無(wú)法修改主鍵的問(wèn)題分析及解決方案,需要的朋友可以參考下

問(wèn)題背景

同事咨詢了一個(gè)問(wèn)題,TDSQL(for MySQL)中的某張表主鍵需要改為聯(lián)合主鍵,是否必須先刪除現(xiàn)有的主鍵?因?yàn)閯h除主鍵時(shí),提示這個(gè)錯(cuò)誤。

[test]> alter table test drop primary key;
ERROR 3750 (HY000): Unable to create or change a table without a primary key, 
when the system variable 'sql_require_primary_key' is set. 
Add a primary key to the table or unset this variable to avoid this message. 
Note that tables without a primary key can cause performance problems in row-based replication, 
so please consult your DBA before changing this setting.

問(wèn)題分析

從提示上可以看到具體的原因,當(dāng)設(shè)置了 sql_require_primary_key 參數(shù),不能創(chuàng)建或改變一張沒(méi)有主鍵的表。解決方案是增加主鍵或者刪除此參數(shù)避免錯(cuò)誤,同時(shí)提醒了,如果表無(wú)主鍵,可能會(huì)導(dǎo)致基于行的復(fù)制產(chǎn)生性能問(wèn)題。

sql_require_primary_key 參數(shù)控制的是強(qiáng)制檢查主鍵,可以動(dòng)態(tài)修改。

參數(shù)名稱:sql_require_primary_key
作用范圍:Global & Session
動(dòng)態(tài)修改:Yes
默認(rèn)值:OFF
該參數(shù)設(shè)置為ON時(shí),SQL語(yǔ)句create table創(chuàng)建新表或者alter語(yǔ)句對(duì)已存在的表進(jìn)行修改,將會(huì)強(qiáng)制檢查表中是否包含主鍵,如果沒(méi)有主鍵,則會(huì)報(bào)錯(cuò)。

針對(duì)這個(gè)場(chǎng)景,是否還可以將主鍵改為聯(lián)合主鍵?

創(chuàng)建一張測(cè)試表,主鍵初始是 id

bisal@mysqldb:  [test]> create table t_primary_key (id int, c1 varchar(1), c2 varchar(1), constraint pk_t_id primary key(id));
Query OK, 0 rows affected (0.07 sec)

解決方案

方案一

既然 sql_require_primary_key 參數(shù)控制了強(qiáng)制檢驗(yàn)主鍵,而且又是可動(dòng)態(tài)修改的,臨時(shí)關(guān)閉,再打開即可。

bisal@mysqldb:  [test]> alter table t_primary_key drop primary key;
ERROR 3750 (HY000): Unable to create or change a table without a primary key, when the system variable 'sql_require_primary_key' is set. Add a primary key to the table or unset this variable to avo

bisal@mysqldb:  [(none)]> show variables like '%sql_require%';
+-------------------------+-------+
| Variable_name           | Value |
+-------------------------+-------+
| sql_require_primary_key | OFF   |
+-------------------------+-------+
1 row in set (0.00 sec)

bisal@mysqldb:  [(none)]> set sql_require_primary_key = ON;
Query OK, 0 rows affected (0.02 sec)

bisal@mysqldb:  [(none)]> show variables like '%sql_require%';
+-------------------------+-------+
| Variable_name           | Value |
+-------------------------+-------+
| sql_require_primary_key | ON    |
+-------------------------+-------+
1 row in set (0.00 sec)

bisal@mysqldb:  [test]> alter table t_primary_key drop primary key;
Query OK, 0 rows affected (0.10 sec)
Records: 0  Duplicates: 0  Warnings: 0

但可能的風(fēng)險(xiǎn),就是刪除主鍵,再創(chuàng)建主鍵的這段時(shí)間內(nèi),如果有主鍵字段的重復(fù)數(shù)據(jù)插入,就可能導(dǎo)致創(chuàng)建新的主鍵不成功。另外,鑒于該參數(shù)設(shè)置成為非默認(rèn)值,創(chuàng)建完主鍵,需要記得改過(guò)來(lái)。

方案二

如果 sql_require_primary_key 設(shè)置為 ON,意思就是表任何的時(shí)刻都需要有主鍵,不能出現(xiàn)真空。變更主鍵的操作,實(shí)際包含了刪除原主鍵和創(chuàng)建新的主鍵兩個(gè)步驟,因此只需要將兩個(gè)步驟合并成一個(gè)即可。

MySQL 支持多個(gè)語(yǔ)句一次執(zhí)行,因此只需要將 alter table ... drop primary keyadd constraint ... primary key ... 合成一條語(yǔ)句。

bisal@mysqldb:  [test]> alter table t_primary_key drop primary key, add constraint pk_t_01 primary key (id, c1);
Query OK, 0 rows affected (0.06 sec)
Records: 0  Duplicates: 0  Warnings: 0

總結(jié)

從這個(gè)問(wèn)題可以看出來(lái),MySQL 的參數(shù)控制粒度很細(xì),但通過(guò)各種應(yīng)對(duì)方法,可以針對(duì)性解決特定的場(chǎng)景問(wèn)題,但前提還是對(duì)參數(shù)的意義,以及場(chǎng)景的需求能充分了解,才能找到合適的解決方案。

關(guān)于 SQLE

SQLE 是一款全方位的 SQL 質(zhì)量管理平臺(tái),覆蓋開發(fā)至生產(chǎn)環(huán)境的 SQL 審核和管理。支持主流的開源、商業(yè)、國(guó)產(chǎn)數(shù)據(jù)庫(kù),為開發(fā)和運(yùn)維提供流程自動(dòng)化能力,提升上線效率,提高數(shù)據(jù)質(zhì)量。

以上就是MySQL無(wú)法修改主鍵的問(wèn)題分析及解決方案的詳細(xì)內(nèi)容,更多關(guān)于MySQL無(wú)法修改主鍵的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 將圖片保存到mysql數(shù)據(jù)庫(kù)并展示在前端頁(yè)面的實(shí)現(xiàn)代碼

    將圖片保存到mysql數(shù)據(jù)庫(kù)并展示在前端頁(yè)面的實(shí)現(xiàn)代碼

    這篇文章主要介紹了將圖片保存到mysql數(shù)據(jù)庫(kù)并展示在前端頁(yè)面,本文給的大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-05-05
  • MySQL總是差八個(gè)小時(shí)該如何解決

    MySQL總是差八個(gè)小時(shí)該如何解決

    最近在用mybatis時(shí)發(fā)現(xiàn),將LocalDateTime插入到數(shù)據(jù)庫(kù)時(shí)時(shí)間少了8小時(shí),下面這篇文章主要給大家介紹了關(guān)于MySQL總是差八個(gè)小時(shí)該如何解決的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • MySQL視圖的概念和操作函數(shù)詳解

    MySQL視圖的概念和操作函數(shù)詳解

    對(duì)MySQL數(shù)據(jù)庫(kù)的查詢,除了基本的查詢外,有時(shí)候需要對(duì)查詢的結(jié)果集進(jìn)行處理,下面這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)庫(kù)基本SQL語(yǔ)句教程之高級(jí)操作中視圖的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • Windows中Mysql啟動(dòng)失敗的完美解決方案

    Windows中Mysql啟動(dòng)失敗的完美解決方案

    這篇文章主要介紹了Windows中Mysql啟動(dòng)失敗解決方案,mysql服務(wù)啟動(dòng)失敗分為2種情況給大家詳細(xì)介紹,針對(duì)每一種給大家詳細(xì)解決,需要的朋友可以參考下
    2022-10-10
  • mysql5.7.42到mysql8.2.0的升級(jí)(rpm方式)

    mysql5.7.42到mysql8.2.0的升級(jí)(rpm方式)

    隨著數(shù)據(jù)量的增長(zhǎng)和業(yè)務(wù)需求的變更,我們可能需要升級(jí)MySQL,本文主要介紹了mysql5.7.42到mysql8.2.0的升級(jí)(rpm方式),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-03
  • mysql 5.6 壓縮包版安裝方法

    mysql 5.6 壓縮包版安裝方法

    這篇文章主要為大家詳細(xì)介紹了mysql 5.6 壓縮包版安裝方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • MySQL中查詢?nèi)罩九c慢查詢?nèi)罩镜幕緦W(xué)習(xí)教程

    MySQL中查詢?nèi)罩九c慢查詢?nèi)罩镜幕緦W(xué)習(xí)教程

    這篇文章主要介紹了MySQL中查詢?nèi)罩九c慢查詢?nèi)罩镜幕緦W(xué)習(xí)教程,文中還提到了MySQL自帶的Mysqldumpslow日志分析工具的使用,需要的朋友可以參考下
    2015-12-12
  • MySQL的Redo Log數(shù)據(jù)恢復(fù)核心機(jī)制面試精講

    MySQL的Redo Log數(shù)據(jù)恢復(fù)核心機(jī)制面試精講

    這篇文章主要為大家介紹了MySQL的Redo Log數(shù)據(jù)恢復(fù)核心機(jī)制面試精講,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • mysql千萬(wàn)級(jí)數(shù)據(jù)大表該如何優(yōu)化?

    mysql千萬(wàn)級(jí)數(shù)據(jù)大表該如何優(yōu)化?

    如何設(shè)計(jì)或優(yōu)化千萬(wàn)級(jí)別的大表?此外無(wú)其他信息,個(gè)人覺(jué)得這個(gè)話題有點(diǎn)范,就只好簡(jiǎn)單說(shuō)下該如何做,對(duì)于一個(gè)存儲(chǔ)設(shè)計(jì),必須考慮業(yè)務(wù)特點(diǎn),收集的信息如下
    2011-08-08
  • mysql計(jì)算時(shí)間差函數(shù)

    mysql計(jì)算時(shí)間差函數(shù)

    MySql計(jì)算兩個(gè)日期的時(shí)間差函數(shù)TIMESTAMPDIFF用法,只要用一句SQL語(yǔ)句就可以辦到了。
    2013-11-11

最新評(píng)論