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

MySQL數(shù)據(jù)表設(shè)計(jì)之自動增長的實(shí)現(xiàn)

 更新時(shí)間:2025年03月12日 10:41:45   作者:堅(jiān)持就完事了  
本文主要介紹了MySQL數(shù)據(jù)表設(shè)計(jì)之自動增長的實(shí)現(xiàn),包括創(chuàng)建數(shù)據(jù)表時(shí)設(shè)置自動增長和修改數(shù)據(jù)表時(shí)添加自動增長,具有一定的參考價(jià)值,感興趣的可以了解一下

在實(shí)際開發(fā)中,有時(shí)需要為數(shù)據(jù)表中添加的新紀(jì)錄自動生成主鍵值。例如在員工數(shù)據(jù)表中添加員工信息時(shí),如果手動填寫員工工號,需要在添加員工前查詢工號是否被其他員工占用,由于先查詢后添加需要一段時(shí)間,有可能會出現(xiàn)并發(fā)操作時(shí)工號被其他人搶占的問題,此時(shí)可以為員工工號字段設(shè)置自動增長。設(shè)置自動增長后,如果往該字段插入值時(shí),MySQL會自動生成唯一的自動增長值。

通過給字段設(shè)置AUTO_INCREMENT即可實(shí)現(xiàn)自動增長。

設(shè)置自動增長的方式有兩種,分別為創(chuàng)建數(shù)據(jù)表時(shí)設(shè)置自動增長和修改數(shù)據(jù)表時(shí)添加自動增長。

1.創(chuàng)建數(shù)據(jù)表時(shí)設(shè)置自動增長

CREATE TABLE 表名 (
字段名 數(shù)據(jù)類型 約束 AUTO_INCREMENT,
...
);

2.修改數(shù)據(jù)表時(shí)添加自動增長

# 語法1 MODIFY子句
ALTER TABLE 表名 MODIFY 字段名 數(shù)據(jù)類型 AUTO_INCREMENT;

# 語法2 CHANGE子句
ALTER TABLE 表名 CHANGE 字段名 字段名 數(shù)據(jù)類型 AUTO_INCREMENT;

3.使用AUTO_INCREMENT時(shí)注意事項(xiàng)如下:

  • 一個(gè)數(shù)據(jù)表中只能有一個(gè)字段設(shè)置AUTO_INCREMENT,設(shè)置AUTO_INCREMENT字段的數(shù)據(jù)類型應(yīng)該是整數(shù)類型,并且該字段必須設(shè)置了唯一約束或主鍵約束
  • 如果為自動增長字段插入NULL、0、DEFAULT,或在插入數(shù)據(jù)時(shí)省略了自動增長字段,則該字段會使用自動增長值;如果插入的是一個(gè)具體的值,則不會使用自動增長值。
  • 默認(rèn)情況下,設(shè)置AUTO_INCREMENT的字段的值會從1開始自增。如果插入了一個(gè)大于自動增長值得具體值,則下次插入的自動增長的值會自動使用最大值加1;如果插入的值小于自動增長值,則不會對自動增長值產(chǎn)生影響
  • 使用DELETE語句刪除數(shù)據(jù)時(shí),自動增長值不會減少或填補(bǔ)空缺
  • 在為字段刪除自動增長并重新添加自動增長后,自動增長的初始值會自動設(shè)置為該列現(xiàn)有的最大值加1
  • 在修改自動增長值時(shí),修改的值若小于該列現(xiàn)有的最大值,則修改不會生效

4.示例

1.創(chuàng)建數(shù)據(jù)表,設(shè)置id字段自動增長

mysql> create table my_auto (
    -> id int primary key auto_increment,
    -> username varchar(20)
    -> );
Query OK, 0 rows affected (0.04 sec)

2.使用DESC語句查看表結(jié)構(gòu),驗(yàn)證id字段是否成功設(shè)置主鍵和自動增長

mysql> desc my_auto;
+----------+-------------+------+-----+---------+----------------+
| Field    | Type        | Null | Key | Default | Extra          |
+----------+-------------+------+-----+---------+----------------+
| id       | int         | NO   | PRI | NULL    | auto_increment |
| username | varchar(20) | YES  |     | NULL    |                |
+----------+-------------+------+-----+---------+----------------+
2 rows in set (0.01 sec)

3.添加數(shù)據(jù)進(jìn)行測試,這里省略id字段,并查詢結(jié)果,從結(jié)果可知省略id字段后id字段會使用自動增長值。從1開始

mysql> select * from my_auto;
+----+----------+
| id | username |
+----+----------+
|  1 | a        |
+----+----------+
1 row in set (0.00 sec)

4.添加數(shù)據(jù)進(jìn)行測試,這里在id字段插入NULL值,從結(jié)果得知id字段使用自動增長值

mysql> insert into my_auto values (null,'b');
Query OK, 1 row affected (0.01 sec)

mysql> select * from my_auto;
+----+----------+
| id | username |
+----+----------+
|  1 | a        |
|  2 | b        |
+----+----------+
2 rows in set (0.00 sec)

5.添加數(shù)據(jù)時(shí),在id字段插入具體值5,從結(jié)果可知id字段的值從5開始自增

mysql> insert into my_auto values (5,'c');
Query OK, 1 row affected (0.01 sec)

mysql> select * from my_auto;
+----+----------+
| id | username |
+----+----------+
|  1 | a        |
|  2 | b        |
|  5 | c        |
+----+----------+
3 rows in set (0.00 sec)

6.添加數(shù)據(jù)時(shí),在id字段添加0,使用自動增長,從5開始自增,加一變成6

mysql> insert into my_auto values (0,'d');
Query OK, 1 row affected (0.00 sec)

mysql> select * from my_auto;
+----+----------+
| id | username |
+----+----------+
|  1 | a        |
|  2 | b        |
|  5 | c        |
|  6 | d        |
+----+----------+
4 rows in set (0.00 sec)

7.添加數(shù)據(jù)時(shí),在id字段添加DEFAULT值,使用自動增長

mysql> insert into my_auto values (default,'e');
Query OK, 1 row affected (0.01 sec)

mysql> select * from my_auto;
+----+----------+
| id | username |
+----+----------+
|  1 | a        |
|  2 | b        |
|  5 | c        |
|  6 | d        |
|  7 | e        |
+----+----------+
5 rows in set (0.00 sec)

8.使用SHOW CREATE TABLE語句查看自動增長值,從查詢結(jié)果可知AUTO_INCREMENT=8表明下次插入的自動增長值為8,若下次插入的指定了大于8的值,此處的8會自動更新為下次插入值加1

mysql> show create table my_auto\G
*************************** 1. row ***************************
       Table: my_auto
Create Table: CREATE TABLE `my_auto` (
  `id` int NOT NULL AUTO_INCREMENT,
  `username` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
1 row in set (0.00 sec)

9.先修改id的自動增長值為10,然后在刪除id字段的自動增長,最后再重新為id字段設(shè)置自動增長

mysql> # 刪除自動增長
mysql> alter table my_auto modify id int;
Query OK, 5 rows affected (0.06 sec)
Records: 5  Duplicates: 0  Warnings: 0

mysql> desc my_auto;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id       | int         | NO   | PRI | NULL    |       |
| username | varchar(20) | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

mysql> show create table my_auto\G
*************************** 1. row ***************************
       Table: my_auto
Create Table: CREATE TABLE `my_auto` (
  `id` int NOT NULL,
  `username` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
1 row in set (0.00 sec)

mysql> # 重新為id字段添加自動增長
mysql> alter table my_auto modify id int auto_increment;
Query OK, 5 rows affected (0.03 sec)
Records: 5  Duplicates: 0  Warnings: 0

mysql> desc my_auto;
+----------+-------------+------+-----+---------+----------------+
| Field    | Type        | Null | Key | Default | Extra          |
+----------+-------------+------+-----+---------+----------------+
| id       | int         | NO   | PRI | NULL    | auto_increment |
| username | varchar(20) | YES  |     | NULL    |                |
+----------+-------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)

mysql> show create table my_auto\G
*************************** 1. row ***************************
       Table: my_auto
Create Table: CREATE TABLE `my_auto` (
  `id` int NOT NULL AUTO_INCREMENT,
  `username` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
1 row in set (0.00 sec)

5.擴(kuò)展

MySQL中提供了兩個(gè)用于維護(hù)自動增長的系統(tǒng)變量,分別是AUTO_INCREMENT_MENT和AUTO_INCREMENT_OFFEST,前者表示自增長自動從哪個(gè)數(shù)開始,它的取值范圍是1~65535;后者表示自增長字段每次遞增的量。默認(rèn)為1,取值范圍是1~65535

若要查看這兩個(gè)變量的值,可以使用SHOW VARIABLES語句

如:

mysql> show variables like 'auto_inc%';
+--------------------------+-------+
| Variable_name            | Value |
+--------------------------+-------+
| auto_increment_increment | 1     |
| auto_increment_offset    | 1     |
+--------------------------+-------+
2 rows in set, 1 warning (0.00 sec)

若要改變自動增長的計(jì)算方式,可以通過改變這兩個(gè)變量的值來實(shí)現(xiàn)。例如,可以使用

SET @@auto_increment_increment = 10;

將auto_increment_increment的值改為10 ,這里僅介紹如何查看自動增長系統(tǒng)變量的值,關(guān)于變量的相關(guān)內(nèi)容將會在數(shù)據(jù)庫編程章節(jié)中的函數(shù)模塊中學(xué)習(xí)

到此這篇關(guān)于MySQL數(shù)據(jù)表設(shè)計(jì)之自動增長的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)MySQL 自動增長內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql查詢使用_rowid虛擬列的示例

    mysql查詢使用_rowid虛擬列的示例

    MySQL中,_rowid是InnoDB虛擬列,用于無主鍵表的行ID查詢,若存在主鍵或唯一列,則指向其,否則使用隱藏ID(不穩(wěn)定),推薦使用ROW_NUMBER()或變量模擬,且應(yīng)顯式定義主鍵以確保穩(wěn)定性,對mysql,_rowid虛擬列相關(guān)知識感興趣的朋友一起看看吧
    2025-06-06
  • MySQL中Case?When用法及說明

    MySQL中Case?When用法及說明

    這篇文章主要介紹了MySQL中Case?When用法及說明,具有很好的參考價(jià)值,希望對大家有所幫助。
    2022-12-12
  • mysql回表致索引失效案例講解

    mysql回表致索引失效案例講解

    這篇文章主要介紹了mysql回表致索引失效案例講解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • MySQL中substr()函數(shù)的使用示例

    MySQL中substr()函數(shù)的使用示例

    mysql?substr函數(shù)是用來截取數(shù)據(jù)庫某一列字段中的一部分,本文主要介紹了MySQL中substr()函數(shù)的使用示例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-04-04
  • MySQL如何設(shè)置動態(tài)創(chuàng)建時(shí)間(create_time)和修改時(shí)間(update_time)

    MySQL如何設(shè)置動態(tài)創(chuàng)建時(shí)間(create_time)和修改時(shí)間(update_time)

    本文主要介紹了MySQL如何設(shè)置動態(tài)創(chuàng)建時(shí)間(create_time)和修改時(shí)間(update_time),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • MySQL刪除表三種操作及delete、truncate、drop語句的區(qū)別

    MySQL刪除表三種操作及delete、truncate、drop語句的區(qū)別

    文章主要介紹了MySQL中三種刪除表的操作:delete語句、truncate語句和drop語句,它們的區(qū)別在于功能、用法、執(zhí)行速度、使用場景、表和索引所占空間以及是否可回滾等方面,感興趣的朋友跟隨小編一起看看吧
    2025-03-03
  • MySQL查詢數(shù)據(jù)庫所有表名以及表結(jié)構(gòu)其注釋(小白專用)

    MySQL查詢數(shù)據(jù)庫所有表名以及表結(jié)構(gòu)其注釋(小白專用)

    查詢數(shù)據(jù)庫所有表的表名、備注,其實(shí)也是比較常見的操作,這篇文章主要給大家介紹了關(guān)于MySQL查詢數(shù)據(jù)庫所有表名以及表結(jié)構(gòu)其注釋的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2024-08-08
  • MySQL多表數(shù)據(jù)記錄查詢詳解

    MySQL多表數(shù)據(jù)記錄查詢詳解

    這篇文章主要為大家詳細(xì)介紹了MySQL多表數(shù)據(jù)記錄查詢操作,具有一定的實(shí)用性,感興趣的小伙伴們可以參考一下
    2016-08-08
  • 使用mysql中遇到的幾個(gè)問題

    使用mysql中遇到的幾個(gè)問題

    首先mysql不是可視化的,可以通過命令行進(jìn)行操作,包括創(chuàng)建數(shù)據(jù)庫、表、添加數(shù)據(jù)等等。那豈不是很不方便了嗎?
    2009-07-07
  • MySQL中從庫延遲狀況排查的一則案例

    MySQL中從庫延遲狀況排查的一則案例

    這篇文章主要介紹了MySQL中從庫延遲狀況排查的一則案例,針對其從庫無業(yè)務(wù)狀態(tài)下的CPU大量占用情況,需要的朋友可以參考下
    2015-05-05

最新評論