既然你知道怎样输入命令现在是存取一个数据库的时候了
假定在你的家(你的动物园)中有很多宠物并且你想追蹤关于他们各种各样类型的信息你可以通过创建表来保存你的数据并根据所需要的信息装载他们做到然后你可以通过从表中检索数据来回答关于你的动物不同种类的问题本节显示如何做到所有这些事情
怎样创建一个数据库
怎样创建一个数据库表
怎样装载数据到数据库表
怎样以各种方法从表中检索数据
怎样使用多个表
动物园数据库将会是简单的(故意的)但是不难把它想象成可能用到相似类型数据库的真实世界情况例如这样的一个数据库能被一个农夫用来追蹤家畜或由一个兽医追蹤病畜记录
使用SHOW语句找出在服务器上当前存在什么数据库
mysql> SHOW DATABASES;
++
| Database |
++
| mysql|
| test |
| tmp|
++
数据库列表可能在你的机器上是不同的但是mysql和test数据库很可能的在其间mysql是必需的因为它描述用户存取权限test数据库经常作为一个工作区提供给用户试试身手
如果test数据库存在尝试存取它
mysql> USE test
Database changed
注意USE类似QUIT不需要一个分号(如果你喜欢你可以用一个分号终止这样的语句这无碍)USE语句在使用上也有另外一个特殊的地方它必须在一个单行上给出
你可列在后面的例子中使用test数据库(如果你能访问它)但是你在该数据库创建的任何东西可以被与访问它的其他人删除为了这个原因你可能应该询问你的MySQL管理员许可你自己使用的一个数据库假定你想要调用你的menagerie管理员需要执行一个这样的命令
mysql> GRANT ALL ON menagerie* TO your_mysql_name;
这里your_mysql_name是分配给你的MySQL用户名
创建并选用一个数据库
如果在设置你的权限时管理员为你创建了数据库你可以开始使用它否则你需要自己创建它
mysql> CREATE DATABASE menagerie;
在Unix下数据库名字是区分大小写的(不像SQL关键词)因此你必须总是以menagerie引用你的数据库不是MenagerieMENAGERIE或一些其他变种对表名也是这样的(在Windows下该限制不适用尽管你必须在一个给定的查询中使用同样的大小写来引用数据库和表)
创建了一个数据库并不选定以使用它你必须明确地做这件事为了使menagerie称为当前的数据库使用这个命令
mysql> USE menagerie
Database changed
你的数据库只需要创建一次但是你必须在每次启动一个mysql会话时为使用而选择它你可以由发出上面一个USE语句做到另外当你调用时mysql你可在命令行上选择数据库就在你可能需要提供的任何连接参数之后指定其名字例如
shell> mysql h host u user p menagerie
Enter password: ********
注意menagerie不是你在刚才所示命令的口令如果你想要在命令行上在p选项后提供你的口令你必须做到没有多余的空格(例如如pmypassword不是p mypassword)然而不建议把你的口令放在命令行上因为这样做把它暴露出来能被在你的机器上登录的其他用户窥探到
创建一个数据库表
创建数据库是容易的部分但是在这时它是空的正如SHOW TABLES将告诉你
mysql> SHOW TABLES;
Empty set ( sec)
较难的部分是决定你的数据库结构应该是什么你将需要什么数据库表和在他们中有什么样的列
你将需要一个包含你每个宠物的记录的表它可称为pet表并且它应该包含最少每个动物的名字因为名字本身不是很有趣表应该包含另外的信息例如如果在你豢养宠物的家庭有超过一个人你可能想要列出每个动物的主人你可能也想要记录例如种类和性别的一些基本的描述信息
年龄呢?那可能有趣但是在一个数据库中存储不是一件好事情年龄随着时间流逝而变化这意味着你将要不断地更新你的记录相反 存储一个固定值例如生日比较好那么无论何时你需要年龄你可以以当前日期和出生日期之间的差别来计算它MySQL为日期运算提供了函数因此这并不困难存储出生日期而非年龄也有其他优点
你可以将数据库用于这样的任务例如生成即将到来的宠物生日的提示(如果你认为这类查询是点蠢注意这与在一个商务数据库来标示你不久要给它发出生日祝贺的客户的环境中是同一个问题因为计算机帮助私人联络)
你可以相对于日期而不止是当前日期来计算年龄例如如果你在数据库存储死亡日期你能容易计算一只宠物是何时多大死的
你可能想到pet表中其他有用的其他类型信息但是到目前为止这些现在是足够了名字主人种类性别出生和死亡日期
使用一个CREATE TABLE语句指定你的数据库表的布局
mysql> CREATE TABLE pet (name VARCHAR() owner VARCHAR()
> species VARCHAR() sex CHAR() birth DATE death DATE);
VARCHAR对nameowner和species列是个好的选择因为列值将会是变长的这些列的长度都不必是相同的而且不必是你可以挑选从到的任何长度无论哪个对你来说好象最合理(如果你做了较差的选择以后会变得你需要一个更长的字段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() | YES| | NULL| |
| owner | varchar() | YES| | NULL| |
| species | varchar() | YES| | NULL| |
| sex | char() | YES| | NULL| |
| birth | date| YES| | NULL| |
| death | date| YES| | NULL| |
+++++++
你能随时DESCRIBE例如如果你忘记在你表中的列的名字或他们是什么类型
将数据装入一个数据库表
在你创建表后你需要充实它LOAD DATA和INSERT语句用于此
假定你的宠物纪录描述如下(观察到MySQL期望日期时以YYYYMMDD格式这可能与你习惯的不同)
nameownerspeciessexbirthdeath
FluffyHaroldcatf
ClawsGwencatm
BuffyHarolddogf
FangBennydogm
BowserDianedogm
ChirpyGwenbirdf
WhistlerGwenbird
SlimBennysnakem
因为你是从一张空表开始的充实它的一个容易方法是创建包含为你的动物各一行一个文本文件然后用一个单个语句装载文件的内容到表中
你可以创建一个文本文件pettxt每行包含一个记录用定位符(tab)把值分开并且以在CREATE TABLE语句中列出的列次序给出对于丢失的值(例如未知的性别或仍然活着的动物的死亡日期)你可以使用NULL值为了在你的文本文件表示这些使用\N例如对Whistler鸟的记录看起来像这样的(这里在值之间的空白是一个单个的定位字符)
WhistlerGwenbird\N\N
为了装载文本文件pettxt到pet表中使用这个命令
mysql> LOAD DATA LOCAL INFILE pettxt INTO TABLE pet;
如果你愿意你能明确地在LOAD DATA语句中指出列值的分隔符和行尾标记但是缺省是定位符和换行符这些对争取读入文件pettxt的语句是足够的
当你想要一次增加一个新记录时INSERT语句是有用的在它最简单的形式你为每一列提供值以列在CREATE TABLE语句被列出的顺序假定Diane把一只新仓鼠命名为Puffball你可以使用一个这样INSERT语句增加一条新记录
mysql> INSERT INTO pet
> VALUES (PuffballDianehamsterfNULL);
注意这里字符串和日期值被指定为引号扩起来的字符串另外用INSERT你能直接插入NULL代表不存在的值你不能使用\N就像你用LOAD DATA做