1.建立表格
建立資料庫是很容易的部分,但是在這時它是空的,正如SHOW TABLES將告訴你的:
mysql> SHOW TABLES; Empty set (0.00 sec)
較難的部分是決定你的資料庫結構應該是什麼:你需要什麼資料庫表,各資料庫表中有什麼樣的欄位。
你將需要一個包含你每個寵物的記錄的表。它可稱為pet表,並且它應該包含,最少,每個動物的名字。因為名字本身不是很有趣,表應該包含另外的資訊。例如,如果在你豢養寵物的家庭有超過一個人,你可能會想要列出每個動物的主人。你可能也想要記錄例如種類和性別的一些基本的描述資訊。
年齡呢?那可能很有趣,但是儲存到一個資料庫中不是一件好事情。年齡隨著時間流逝而變化,這意味著你將要不斷地更新你的記錄。相反, 儲存一個固定值例如生日比較好,那麼,無論何時你需要年齡,可以以當前日期和出生日期之間的差來計算它。 MySQL提供了日期運算函數,因此這並不困難。儲存出生日期而非年齡還有其它優點:
· 你可以使用資料庫完成這樣的任務,例如產生即將到來的寵物生日的提示。 (如果你認為這類詢問有點蠢,注意,這與從商務資料庫來識別出不久要發給生日祝賀的客戶是同一個問題,因為電腦幫助私人聯絡。)
· 你可以相對於日期而不止是當前日期來計算年齡。例如,如果你在資料庫儲存死亡日期,你能輕易地計算出一隻寵物死時有多大。
你可能想到pet表中其它有用的其它類型信息,但是到目前為止這些已經足夠了:名字、主人、種類,性別、出生和死亡日期。
使用一個CREATE TABLE語句指定你的資料庫表的版面:
mysql> CREATE TABLE pet (name VARCHAR(20), owner VARCHAR(20), -> species VARCHAR(20), sex CHAR(1), birth DATE, death DATE);
VARCHAR適合name、owner和species列,因為欄位值是變長的。這些列的長度不必都相同,而且不必是20。你可以挑選從1到65535的任何長度,從中選擇一個最合理的值。 (如果選擇得不合適,後來證明你需要一個更長的字段,MySQL提供一個ALTER TABLE語句。)
可以用多種類型的值來表示動物記錄中的性別,例如,"m"和"f ",或"male"和"female"。使用單字元"m"和"f"是最簡單的方法。
很顯然,birth和death列應選用DATE資料類別。
創建了資料庫表後,SHOW TABLES應該產生一些輸出:
mysql> SHOW TABLES; +---------------------+ | Tables in menagerie | +---------------------+ | pet | +---------------------+
為了驗證你的表是按你期望的方式創建,使用一個DESCRIBE語句:
mysql> DESCRIBE pet;
+---------+ -------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+---------+-------------+------+-----+-- -------+-------+
| name | varchar(20) | YES | | NULL | |
| owner | var |🎠
| species | varchar(20) | YES | | NULL | |
| sex | char(1) date | YES | | NULL | |
| death |
+---------+-------------+------+-----+---------+- ------+
你可以隨時使用DESCRIBE,例如,如果你忘記表格中的欄位的名稱或類型時。
Buffy Harold dog f 1989-05-13
Fang Benny dog m 1990-08-27
Bowser Diane dog m 1979-08-31 1995-07-29
Chirpy Gwen bird f 1998-09-11
Whistler Gwen bird 1997-12-09
Slim Benny snake m 1996-04-29
因为你是从一个空表开始的,填充它的一个简易方法是创建一个文本文件,每个动物各一行,然后用一个语句将文件的内容装载到表中。
你可以创建一个文本文件“pet.txt”,每行包含一个记录,用定位符(tab)把值分开,并且以CREATE TABLE语句中列出的列次序给出。对于丢失的值(例如未知的性别,或仍然活着的动物的死亡日期),你可以使用NULL值。为了在你的文本文件中表示这些内容,使用\N(反斜线,字母N)。例如,Whistler鸟的记录应为(这里值之间的空白是一个定位符):
name owner species sex birth death
Whistler Gwen bird \N 1997-12-09 \N
要想将文本文件“pet.txt”装载到pet表中,使用这个命令:
mysql> LOAD DATA LOCAL INFILE '/path/pet.txt' INTO TABLE pet;
请注意如果用Windows中的编辑器(使用\r\n做为行的结束符)创建文件,应使用:
mysql> LOAD DATA LOCAL INFILE '/path/pet.txt' INTO TABLE pet -> LINES TERMINATED BY '\r\n';
(在运行OS X的Apple机上,应使用行结束符'\r'。)
如果你愿意,你能明确地在LOAD DATA语句中指出列值的分隔符和行尾标记,但是默认标记是定位符和换行符。这对读入文件“pet.txt”的语句已经足够。
如果该语句失败,可能是你安装的MySQL不与使用默认值的本地文件兼容。
如果想要一次增加一个新记录,可以使用INSERT语句。最简单的形式是,提供每一列的值,其顺序与CREATE TABLE语句中列的顺序相同。假定Diane把一只新仓鼠命名为Puffball,你可以使用下面的INSERT语句添加一条新记录:
mysql> INSERT INTO pet -> VALUES ('Puffball','Diane','hamster','f','1999-03-30',NULL);
注意,这里字符串和日期值均为引号扩起来的字符串。另外,可以直接用INSERT语句插入NULL代表不存在的值。不能使用LOAD DATA中所示的的\N。
从这个例子,你应该能看到涉及很多的键入用多个INSERT语句而非单个LOAD DATA语句装载你的初始记录。