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

詳解MySQL語句中的DDL

 更新時間:2023年06月04日 10:33:31   作者:啊蘇要學習  
這篇文章主要詳細介紹了SQL語句中的DDL,文章中有詳細的代碼示例以及圖文介紹,對我們的學習或工作有一定的幫助,感興趣的同學可以參考閱讀

一.DDL數(shù)據(jù)庫語句

1.1語句講解

DDL是數(shù)據(jù)定義語言,用來對數(shù)據(jù)庫、表、字段進行操作。

show databases;

這句代碼是讓命令行窗口顯示服務器里一共有多少個數(shù)據(jù)庫,請看下圖:

MySQL系統(tǒng)軟件下載后,里面默認有四個系統(tǒng)數(shù)據(jù)庫。

create database if not exists 數(shù)據(jù)庫名 default charset utf8mb4;

這句代碼是創(chuàng)建一個數(shù)據(jù)庫的DDL語句。其中的if not exists 和 default charset utf8mb4是可以省略的。

if not exists的作用是,如果存在test這個數(shù)據(jù)庫,這句代碼什么都不執(zhí)行,不存在就創(chuàng)建test數(shù)據(jù)庫。

下滑線部分表示數(shù)據(jù)庫創(chuàng)建成功。

補充:數(shù)據(jù)庫中有些字符用3個字節(jié)不夠表示,utf8的大小是3個字節(jié),utf8mb4是4個字節(jié)大小。

use 數(shù)據(jù)庫名;

這句代碼的作用是指定使用數(shù)據(jù)庫;

在一般情況下,對一個數(shù)據(jù)庫里的表、字段進行多步操作后,已經(jīng)忘了自己所處的數(shù)據(jù)庫,使用這句代碼:

select database();

這句代碼可以指出現(xiàn)在處在哪個數(shù)據(jù)庫。

drop database if exists 數(shù)據(jù)庫名;

這句代碼是刪除數(shù)據(jù)庫的代碼,if exists可以省略,意思是如果存在test數(shù)據(jù)庫就刪除,否則不執(zhí)行任何操作。

1.2總結

DDL語句對數(shù)據(jù)庫的操作有如下:

二.DDL表語句

2.1語句講解

數(shù)據(jù)庫的數(shù)據(jù)模型里,數(shù)據(jù)庫里包含表,所以在講表的知識,先創(chuàng)建一個數(shù)據(jù)庫先。

show tables;

查詢當前使用數(shù)據(jù)庫里包含的所有表。

由于是新建的數(shù)據(jù)庫,所以是空表Empty。

create table employee(
id int comment '編號',
gender char(1) comment '性別',
age tinyint unsigned comment '年齡'
)comment '員工表';

這是創(chuàng)建表的代碼,我們來慢慢分析,別怕!

首先create table是創(chuàng)建表的意思,這個表名是employee。
接著id、gender、age是表格的字段名、int、char(1)、tinyint是數(shù)據(jù)類型。
最后comment這一部分是注釋,可以省略。

每一個字段與另一個字段之間用逗號隔開,最后一個不加逗號。

desc 表名;

這句代碼可以顯示表的字段名,字段的數(shù)據(jù)類型。

但是看不到注釋,雖然我們知道id可能是編號的意思,但是什么編號就不知道了,普通人?門診號?還有一種查表的語句:

show create table 表名;

這句代碼的意思是,展示創(chuàng)建表時的語句。

alter table 表名 rename to 新表名;

這句代碼的意思是選擇原先的表名,改成新的表名。

drop table if exists 表名;

這句代碼是用來刪除指定表名的表,if exists可以省略,它的意思同前面用到的地方意思是一樣的。

刪完之后,test數(shù)據(jù)庫里就沒有表了,所以再次顯示表的信息時為空。 

truncate table 表名;

這句代碼也是用來刪除表的,但它會重新創(chuàng)建一個相同類型的沒有數(shù)據(jù)的表,但表的結構還在。

比如前面emp這個表不是使用drop而是使用truncate的話,那在show tables的時候,還能看到emp表。

2.2總結

DDL語句對表的操作有如下:

三.DDL字段語句

3.1語句講解

對表中的字段進行操作,也是DDL語句有的屬性。接下來我們就來學習對字段的操作吧~

突然覺得這個表在創(chuàng)建的時候,沒有添加一個信息,想增加一個字段,可以這樣做:

alter table 表名 add 字段名 數(shù)據(jù)類型 [comment '注釋'];

比如想加一個表示薪資的字段:

老板發(fā)現(xiàn)工資用int表示,工資給太高了,想給個小一點的整型表示,于是:

alter table 表名 modify 字段名 新數(shù)據(jù)類型;

這樣就可以改掉原先字段的數(shù)據(jù)類型了,老板很是開心~

后來老板發(fā)現(xiàn),這個薪資不能直接用數(shù)字表現(xiàn)出來,用等級的話隱蔽性會更好,這就需要更換整個字段

alter table 表名 change 舊字段 新字段 新數(shù)據(jù)類型 [comment '注釋']; 

此時,老板的想法達成了。

alter table emp drop 字段名;

這段代碼的意思是刪除指定表的字段名。 

3.2總結

以下是DDL語句對字段的操作:

講到這里,DDL語句的基本操作就講完啦!可能讀者很好奇tinyint、smallint、char(1)這些是什么,我們接下來看。

四.MySQL數(shù)據(jù)類型

SQL里的數(shù)據(jù)類型和其它編程語言有點區(qū)別,但也有相似的地方,它分為三類,我們直接看圖吧。

整型

數(shù)值類型是其中的一種類型,tinyint的大小是一個字節(jié)的整型,相當于C語言里的char類型。

smallint相當于C里的short,bigint相當于C里的long long類型。特殊一點的是mediumint占三個字節(jié)大小。

浮點類型和C是一樣的,有兩點特別的是:decimal和控制浮點數(shù)小數(shù)點保留位數(shù)的方式。

這里得引入兩個概念,精度和標度

  • 精度是浮點數(shù)總共有多少位數(shù),比如3.14的精度是3。
  • 標度是浮點數(shù)有多少個小數(shù)位,6.1的標度是1。

如何表示三位數(shù),一個小數(shù)位呢?首先總共有四個有效位,其次是一個小數(shù)位,是這樣表示的double(4,1)。

在字符串類型里,有char和varchar,學過C語言的讀者會聯(lián)想到表示字符串用char arr[元素個數(shù)]數(shù)組表示。

在MySQL用char(元素個數(shù))表示定長數(shù)組,varchar(元素個數(shù))表示可變數(shù)組。注意不是方括號。

blob是表示二進制數(shù)據(jù)的數(shù)據(jù)類型,text是表示文本數(shù)據(jù)的數(shù)據(jù)類型;

二進制數(shù)據(jù)類型的有軟件包、音頻呀這些。一般不會用數(shù)據(jù)庫存儲的。

tinyblob一個字節(jié)、blob兩個字節(jié)、mediumblob三個字節(jié)、longblob四個字節(jié)、text一樣的,博主不贅述了。

表示日期時間的數(shù)據(jù)類型:

date是表示年月日--- yyyy--mm--dd

time是表示時分秒--- hh--mm--ss

year是表示年--- yyyy

datetime表示年月日,時分秒

timestamp表示的也是年月日,時分秒,不同于datetime的是timestamp是時間戳,由于數(shù)值溢出的原因,在2038年會失效,也叫Unix千年臭蟲。

五.結尾

好啦,到這里就講完SQL語句里的DDL語言,還講了MySQL中的數(shù)據(jù)類型與其它編程語言有一定聯(lián)系,也有區(qū)別。

以上就是詳解MySQL語句中的DDL的詳細內(nèi)容,更多關于MySQL語句DDL的資料請關注腳本之家其它相關文章!

相關文章

最新評論