MySQL DDL(Data Definition Language 數(shù)據(jù)定義語言)

建表

CREATE TABLE `student` (
    `student_id` VARCHAR(32) NOT NULL COMMENT '主鍵',
    `student_name` VARCHAR(50) NOT NULL COMMENT '學生姓名',
    `student_class` VARCHAR(30) NOT NULL COMMENT '學生所在班級',
    `create_time` TIMESTAMP NOT NULL DEFAULT current_timestamp COMMENT '創(chuàng)建時間',
    PRIMARY KEY (`student_id`),
    KEY idx_create_time (`create_time`)
) ENGINE=InnoDB, DEFAULT CHARSET=utf8 COMMENT '學生表';

說明:
1 - 表名和列名不是用單引號,而是tab鍵的上一個鍵——“點”,否則會報語法錯誤
2 - NOT NULL代表非空,COMMENT后面接的字符串是對該列名的解釋
3 - TIMESTAMP是時間戳類型,設置了默認值為取當前時間current_timestamp
4 - PRIMARY KEY ()設置主鍵,里面用的同樣是“點”
5 - KEY idx_create_time () 設置索引,索引名為idx_create_time
6 - ENGINE=InnoDB, DEFAULT CHARSET=utf8 設置的是數(shù)據(jù)庫使用的引擎和字符集,如果不寫,建表時MySQL也會自動選擇默認的ENGINE和CHARSET。

可以使用指令查看MySQL支持的ENGINE和CHARSET

show engines;
show charset;

AUTO_INCREMENT

create table `student`(
    `student_id` INT AUTO_INCREMENT PRIMARY KEY NOT NULL COMMENT '主鍵', 
    `student_name` varchar(30) NOT NULL COMMENT '學生姓名'
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT '學生表';

在定義列表中使用 AUTO_INCREMENT 默認從1開始增長,且步長為1。

create table `student`(
    `student_id` INT AUTO_INCREMENT PRIMARY KEY NOT NULL COMMENT '主鍵', 
    `student_name` varchar(30) NOT NULL COMMENT '學生姓名'
) ENGINE=InnoDB AUTO_INCREMENT=1000 DEFAULT CHARSET=utf8 COMMENT '學生表';

如果想設置以某個數(shù)字開始增長,在表末尾添加AUTO_INCREMENT=Number

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容