山東省建設(shè)工程招標(biāo)中心網(wǎng)站當(dāng)日網(wǎng)站收錄查詢統(tǒng)計
數(shù)據(jù)庫的操作
對庫的操作
-
SQL通用語法規(guī)則介紹
-
創(chuàng)建數(shù)據(jù)庫
-
使用數(shù)據(jù)庫
-
查詢所有數(shù)據(jù)庫
-
查詢當(dāng)前數(shù)據(jù)庫
-
刪除數(shù)據(jù)庫
對庫中表的操作
🚘🚘🚘正片開始
SQL通用語法規(guī)則介紹
-
SQL語句可以單行或多行書寫,以分號結(jié)尾。
-
SQL語句可以使用空格和縮進(jìn)來增強(qiáng)語句的可讀性。
-
MySQL數(shù)據(jù)庫的SQL語句不區(qū)分大小寫,關(guān)鍵字建議使用大寫,但沒強(qiáng)制規(guī)定。
-
注釋:
- 單行注釋:-- + 注釋內(nèi)容 或者 # +注釋內(nèi)容(MySQL特有)
- 多行注釋:/* 注釋內(nèi)容 */
創(chuàng)建數(shù)據(jù)庫語法
create database [if not exists] 數(shù)據(jù)庫名 [default 字符集][collate 排序規(guī)則];
注:使用上述語法時,[ ] 中的語法可以省略不寫
創(chuàng)建數(shù)據(jù)庫展示效果
mysql> create database test;
Query OK, 1 row affected (0.01 sec)mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| my_db |
| mysql |
| performance_schema |
| sys |
| test |
+--------------------+
6 rows in set (0.00 sec)mysql>
當(dāng)test數(shù)據(jù)庫已存在時我們再次創(chuàng)建則會怎么樣呢?讓我們來試試。
mysql> create database test;
ERROR 1007 (HY000): Can't create database 'test'; database exists
mysql>
可以看見它反饋的結(jié)果是說不能創(chuàng)建數(shù)據(jù)庫,數(shù)據(jù)庫已存在
不妨我們使用一下 if not exists
這個看看
mysql> create database if not exists test;
Query OK, 1 row affected, 1 warning (0.01 sec)mysql>
現(xiàn)在沒有報錯了,只是出現(xiàn)了個警告,在創(chuàng)建數(shù)據(jù)庫時,當(dāng)加上這個if not exists
則系統(tǒng)會檢測你當(dāng)前庫中是否有同名的test數(shù)據(jù)庫如果有則不創(chuàng)建,沒有則創(chuàng)建。
使用數(shù)據(jù)庫語法
use 數(shù)據(jù)庫名;
展示效果
mysql> use test;
Database changed
mysql>
查詢所有數(shù)據(jù)庫語法
show databases;
效果展示
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| my_db |
| mysql |
| performance_schema |
| sys |
| test |
+--------------------+
6 rows in set (0.00 sec)mysql>
查詢當(dāng)前所處數(shù)據(jù)庫語法
select database();
展示效果
mysql> select database();
+------------+
| database() |
+------------+
| test | #當(dāng)前處于test數(shù)據(jù)庫
+------------+
1 row in set (0.00 sec)mysql>
刪除數(shù)據(jù)庫語法
drop database [if exists] 數(shù)據(jù)庫名;
展示效果
刪除前該庫中是有test數(shù)據(jù)庫的
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| my_db |
| mysql |
| performance_schema |
| sys |
| test |
+--------------------+
6 rows in set (0.00 sec)
mysql>
執(zhí)行刪除語句
#test刪除成功mysql> drop database test;
Query OK, 0 rows affected (0.01 sec)mysql>
再次查看數(shù)據(jù)庫中是否有test庫
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| my_db |
| mysql |
| performance_schema |
| sys |
+--------------------+
5 rows in set (0.00 sec)mysql>
可以看見已經(jīng)沒有了
當(dāng)使用 drop database if not exists 數(shù)據(jù)庫名;
這條語句刪數(shù)據(jù)庫時 則有該數(shù)據(jù)庫則刪除,無則不刪,更有安全保障。
創(chuàng)建一個表的語法
create table 表名(字段1 字段1的類型[comment 字段1的注釋],字段2 字段2的類型[comment 字段2的注釋],字段3 字段3的類型[comment 字段3的注釋],字段4 字段4的類型[comment 字段4的注釋],……………………………………………………………字段n 字段n的類型[comment 字段n的注釋]
)[comment 表注釋];
展示效果
mysql> create table mytable(-> id tinyint comment '編號',-> name varchar(5) comment '名字',-> age tinyint comment '年齡',-> address varchar(15) comment '地址',-> tel char(11) comment '電話'-> );
Query OK, 0 rows affected (0.03 sec)mysql>
查詢當(dāng)前數(shù)據(jù)庫所有表的語法
show tables;
展示效果
mysql> show tables;
+----------------+
| Tables_in_test |
+----------------+
| mytable | #mytable 已經(jīng)創(chuàng)建出來了
+----------------+
1 row in set (0.00 sec)mysql> select database();
查詢表結(jié)構(gòu)的語法
desc mytable;
mysql> desc mytable;
+---------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| id | tinyint | YES | | NULL | |
| name | varchar(5) | YES | | NULL | |
| age | tinyint | YES | | NULL | |
| address | varchar(15) | YES | | NULL | |
| tel | char(11) | YES | | NULL | |
+---------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)mysql>
查詢指定表的建表語句的語法
show create table mytable;
展示效果
mysql> show create table mytable;
CREATE TABLE `mytable` (`id` tinyint DEFAULT NULL COMMENT '編號',`name` varchar(5) DEFAULT NULL COMMENT '名字',`age` tinyint DEFAULT NULL COMMENT '年齡',`address` varchar(15) DEFAULT NULL COMMENT '地址',`tel` char(11) DEFAULT NULL COMMENT '電話'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
完結(jié)🎉🎉🎉