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

MySQL 序列 AUTO_INCREMENT詳解及實(shí)例代碼

 更新時(shí)間:2017年02月04日 08:49:27   投稿:lqh  
這篇文章主要介紹了MySQL 序列 AUTO_INCREMENT詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下

MySQL 序列 AUTO_INCREMENT詳解及實(shí)例代碼

MySQL序列是一組整數(shù):1, 2, 3, ...,由于一張數(shù)據(jù)表只能有一個(gè)字段自增主鍵, 如果你想實(shí)現(xiàn)其他字段也實(shí)現(xiàn)自動(dòng)增加,就可以使用MySQL序列來(lái)實(shí)現(xiàn)。

本章我們將介紹如何使用MySQL的序列。

使用AUTO_INCREMENT

MySQL中最簡(jiǎn)單使用序列的方法就是使用 MySQL AUTO_INCREMENT 來(lái)定義列。

實(shí)例

以下實(shí)例中創(chuàng)建了數(shù)據(jù)表insect, insect中id無(wú)需指定值可實(shí)現(xiàn)自動(dòng)增長(zhǎng)。

mysql> CREATE TABLE insect
  -> (
  -> id INT UNSIGNED NOT NULL AUTO_INCREMENT,
  -> PRIMARY KEY (id),
  -> name VARCHAR(30) NOT NULL, # type of insect
  -> date DATE NOT NULL, # date collected
  -> origin VARCHAR(30) NOT NULL # where collected
);
Query OK, 0 rows affected (0.02 sec)
mysql> INSERT INTO insect (id,name,date,origin) VALUES
  -> (NULL,'housefly','2001-09-10','kitchen'),
  -> (NULL,'millipede','2001-09-10','driveway'),
  -> (NULL,'grasshopper','2001-09-10','front yard');
Query OK, 3 rows affected (0.02 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> SELECT * FROM insect ORDER BY id;
+----+-------------+------------+------------+
| id | name    | date    | origin   |
+----+-------------+------------+------------+
| 1 | housefly  | 2001-09-10 | kitchen  |
| 2 | millipede  | 2001-09-10 | driveway  |
| 3 | grasshopper | 2001-09-10 | front yard |
+----+-------------+------------+------------+
3 rows in set (0.00 sec)

 獲取AUTO_INCREMENT值

在MySQL的客戶(hù)端中你可以使用 SQL中的LAST_INSERT_ID( ) 函數(shù)來(lái)獲取最后的插入表中的自增列的值。

在PHP或PERL腳本中也提供了相應(yīng)的函數(shù)來(lái)獲取最后的插入表中的自增列的值。

PERL實(shí)例

使用 mysql_insertid 屬性來(lái)獲取 AUTO_INCREMENT 的值。 實(shí)例如下:

$dbh->do ("INSERT INTO insect (name,date,origin)
VALUES('moth','2001-09-14','windowsill')");
my $seq = $dbh->{mysql_insertid};

PHP實(shí)例

PHP 通過(guò) mysql_insert_id ()函數(shù)來(lái)獲取執(zhí)行的插入SQL語(yǔ)句中 AUTO_INCREMENT列的值。

mysql_query ("INSERT INTO insect (name,date,origin)
VALUES('moth','2001-09-14','windowsill')", $conn_id);
$seq = mysql_insert_id ($conn_id);

 重置序列

如果你刪除了數(shù)據(jù)表中的多條記錄,并希望對(duì)剩下數(shù)據(jù)的AUTO_INCREMENT列進(jìn)行重新排列,那么你可以通過(guò)刪除自增的列,然后重新添加來(lái)實(shí)現(xiàn)。 不過(guò)該操作要非常小心,如果在刪除的同時(shí)又有新記錄添加,有可能會(huì)出現(xiàn)數(shù)據(jù)混亂。操作如下所示:

mysql> ALTER TABLE insect DROP id;
mysql> ALTER TABLE insect
  -> ADD id INT UNSIGNED NOT NULL AUTO_INCREMENT FIRST,
  -> ADD PRIMARY KEY (id);

 設(shè)置序列的開(kāi)始值

一般情況下序列的開(kāi)始值為1,但如果你需要指定一個(gè)開(kāi)始值100,那我們可以通過(guò)以下語(yǔ)句來(lái)實(shí)現(xiàn):

mysql> CREATE TABLE insect
  -> (
  -> id INT UNSIGNED NOT NULL AUTO_INCREMENT = 100,
  -> PRIMARY KEY (id),
  -> name VARCHAR(30) NOT NULL, # type of insect
  -> date DATE NOT NULL, # date collected
  -> origin VARCHAR(30) NOT NULL # where collected
);

或者你也可以在表創(chuàng)建成功后,通過(guò)以下語(yǔ)句來(lái)實(shí)現(xiàn):

mysql> ALTER TABLE t AUTO_INCREMENT = 100;

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

相關(guān)文章

  • Linux服務(wù)上MySQL啟動(dòng)、重啟和關(guān)閉的操作方法

    Linux服務(wù)上MySQL啟動(dòng)、重啟和關(guān)閉的操作方法

    MySQL是一種廣泛使用的開(kāi)源關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),常用于各種規(guī)模的應(yīng)用程序中,在Linux服務(wù)器上管理MySQL服務(wù)是一個(gè)基本的運(yùn)維任務(wù),本文將詳細(xì)介紹如何在Linux系統(tǒng)上啟動(dòng)、重啟和關(guān)閉MySQL服務(wù),涵蓋不同Linux發(fā)行版(如Ubuntu和CentOS)的操作方法
    2024-11-11
  • MySQL如何利用存儲(chǔ)過(guò)程快速生成100萬(wàn)條數(shù)據(jù)詳解

    MySQL如何利用存儲(chǔ)過(guò)程快速生成100萬(wàn)條數(shù)據(jù)詳解

    在MySQL數(shù)據(jù)庫(kù)中,如果要插入上百萬(wàn)級(jí)的記錄,用普通的insertinto來(lái)操作非常不現(xiàn)實(shí),速度慢人力成本高,這篇文章主要給大家介紹了關(guān)于MySQL如何利用存儲(chǔ)過(guò)程快速生成100萬(wàn)條數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下
    2021-08-08
  • 十個(gè)實(shí)用且簡(jiǎn)單的MySQL函數(shù)

    十個(gè)實(shí)用且簡(jiǎn)單的MySQL函數(shù)

    本文給大家分享了十個(gè)實(shí)用且簡(jiǎn)單的MySQL函數(shù),需要的朋友可以參考下
    2018-01-01
  • mysql 8.0.15 版本安裝教程 連接Navicat.list

    mysql 8.0.15 版本安裝教程 連接Navicat.list

    這篇文章主要為大家詳細(xì)介紹了mysql 8.0.15 版本安裝教程,連接Navicat.list,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • MySQL中慢SQL優(yōu)化方法的完整指南

    MySQL中慢SQL優(yōu)化方法的完整指南

    當(dāng)數(shù)據(jù)庫(kù)響應(yīng)時(shí)間超過(guò)500ms時(shí),系統(tǒng)將面臨三大災(zāi)難鏈?zhǔn)椒磻?yīng),所以本文將為大家介紹一下MySQL中慢SQL優(yōu)化的常用方法,有需要的小伙伴可以了解下
    2025-03-03
  • 淺談mysql8.0新特性的坑和解決辦法(小結(jié))

    淺談mysql8.0新特性的坑和解決辦法(小結(jié))

    這篇文章主要介紹了淺談mysql8.0新特性的坑和解決辦法(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • MySQL創(chuàng)建數(shù)據(jù)庫(kù)和創(chuàng)建數(shù)據(jù)表

    MySQL創(chuàng)建數(shù)據(jù)庫(kù)和創(chuàng)建數(shù)據(jù)表

    MySQL?是最常用的數(shù)據(jù)庫(kù),在數(shù)據(jù)庫(kù)操作中,基本都是增刪改查操作,簡(jiǎn)稱(chēng)CRUD。但是,這篇文章主要介紹了數(shù)據(jù)庫(kù)和數(shù)據(jù)表如何創(chuàng)建,想詳細(xì)了解的小伙伴可以參考閱讀一下
    2023-03-03
  • MySQL實(shí)現(xiàn)MYISAM表批量壓縮的方法

    MySQL實(shí)現(xiàn)MYISAM表批量壓縮的方法

    這篇文章主要介紹了MySQL實(shí)現(xiàn)MYISAM表批量壓縮的方法,實(shí)例分析了MySQL使用shell命令批量壓縮MYISAM表的相關(guān)技巧,需要的朋友可以參考下
    2016-04-04
  • MYSQL?常用語(yǔ)句速查(最新整理)

    MYSQL?常用語(yǔ)句速查(最新整理)

    這篇文章主要介紹了MYSQL?常用語(yǔ)句速查,包括庫(kù)級(jí)操作、表級(jí)操作、字段級(jí)操作和數(shù)據(jù)級(jí)操作,需要的朋友可以參考下
    2024-12-12
  • linux下源碼安裝mysql5.6.20教程

    linux下源碼安裝mysql5.6.20教程

    這篇文章主要為大家詳細(xì)介紹了linux下源碼安裝mysql5.6.20教程的相關(guān)資料,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01

最新評(píng)論