Github連結

攝影師:Coral Grandbois,連結:Pexels



1. Database的組成? Database 與 Table 間的關聯?

  • Database是由一堆的Tables(一到多個)所組成(通常tables之間有關係,才會被聚集在一起,而MySQL可以創建很多個database)
  • Tables用來存儲資料(data),而在MySQL中Table是有結構的,指的是在Table中插入的數據需要有一定的結構化標準,而結構就是指的Table的結構

2. Database Level的基本指令




  • 筆記: 指令後面要加一個;


show databases;

mysql> show databases;
+--------------------+
| Database     |
+--------------------+
| information_schema |
| mysql      |
| performance_schema |
| sakila      |
| sys       |
| test       |
| world      |
+--------------------+
7 rows in set (0.00 sec)

裡面為目前有的資料庫(ex. information_schema、mysql、performance_schema、sakila、sys、test、world)


create database ;

  • 創建一個名稱為my_db1
mysql> create database my_db1;
Query OK, 1 row affected (0.00 sec)

檢視當前所有數據庫

mysql> show databases;
+--------------------+
| Database     |
+--------------------+
| information_schema |
| my_db1      |
| mysql      |
| performance_schema |
| sakila      |
| sys       |
| test       |
| world      |
+--------------------+
8 rows in set (0.00 sec)

我們剛剛創建的my_db1就顯示在裡面了

  • 錯誤示範: 名稱使用空格
mysql> create database my db1;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'db1' at line 1

這樣就會報錯喔


drop database ;

  • 刪掉剛剛創建的my_db1資料庫
mysql> drop database my_db1;
Query OK, 0 rows affected (0.00 sec)

檢視當前所有數據庫

mysql> show databases;
+--------------------+
| Database     |
+--------------------+
| information_schema |
| mysql      |
| performance_schema |
| sakila      |
| sys       |
| test       |
| world      |
+--------------------+
7 rows in set (0.00 sec)

my_db1就被拿掉了喔!!


use ;

  • 我們先再創建一個database才能使用(切換)它
mysql> create database my_db1;
Query OK, 1 row affected (0.00 sec)
​
mysql> show databases;
+--------------------+
| Database     |
+--------------------+
| information_schema |
| my_db1      |
| mysql      |
| performance_schema |
| sakila      |
| sys       |
| test       |
| world      |
+--------------------+
8 rows in set (0.00 sec)
  • 切換至my_db1資料庫
mysql> use my_db1;
Database changed


select database();

  • 查看當前使用的資料庫
mysql> select database();
+------------+
| database() |
+------------+
| my_db1  |
+------------+
1 row in set (0.00 sec)
  • 當我們還沒選擇切換至任何資料庫,它就會顯示為Null
mysql> drop database my_db1;
Query OK, 0 rows affected (0.00 sec)
​
mysql> select database();
+------------+
| database() |
+------------+
| NULL   |
+------------+
1 row in set (0.00 sec)





3. 怎麼改變分隔符delimiter(;)? 為什麼需要分隔符(;)?


為什麼需要分隔符(;)?

  • 與許多程式語言一樣,我們都需要告訴系統我們已經寫完命令,如何告知?就是透過分隔符delimiter,而MySQL的預設分隔符為;,這也是為什麼在寫任何指令,執行的時候都需要在後面加上;,如果不寫;那系統就會以為你還沒寫完指令,因此就還不會執行它

沒有打上;就按Enter執行的狀況

mysql> show databases
 ->
 ->

系統就會以為你還要繼續寫

加上;分隔符,告訴系統你已經寫好指令

mysql> show databases
 ->
 -> ;
+--------------------+
| Database     |
+--------------------+
| information_schema |
| mysql      |
| performance_schema |
| sakila      |
| sys       |
| test       |
| world      |
+--------------------+
7 rows in set (0.00 sec)

怎麼改變分隔符delimiter(;)?

  • 使用delimiter <要設定成分隔符的符號>
  • 例子: 我們將&&設定成分隔符
mysql> delimiter &&
mysql> show databases&&
+--------------------+
| Database     |
+--------------------+
| information_schema |
| mysql      |
| performance_schema |
| sakila      |
| sys       |
| test       |
| world      |
+--------------------+
7 rows in set (0.00 sec)



4. SQL語句寫大小寫會影響嗎?


大寫與小寫在SQL中是都一樣的喔

mysql> SHOW DATABASES;
+--------------------+
| Database     |
+--------------------+
| information_schema |
| mysql      |
| performance_schema |
| sakila      |
| sys       |
| test       |
| world      |
+--------------------+
7 rows in set (0.00 sec)
​
mysql> SHOW databases;
+--------------------+
| Database     |
+--------------------+
| information_schema |
| mysql      |
| performance_schema |
| sakila      |
| sys       |
| test       |
| world      |
+--------------------+
7 rows in set (0.00 sec)
​
mysql> show DATABASES;
+--------------------+
| Database     |
+--------------------+
| information_schema |
| mysql      |
| performance_schema |
| sakila      |
| sys       |
| test       |
| world      |
+--------------------+
7 rows in set (0.00 sec)



關於大小寫應該要怎麼使用比較好,大家可以參考下面網路上非常厲害人的寫法,他將依些關鍵字用大寫來書寫,會讓整個語句看起來比較明顯清楚



參考網址: https://stackoverflow.com/questions/292026/is-there-a-good-reason-to-use-upper-case-for-sql-keywords



共同作者

https://matters.news/@queenasu9519