盾怪网教程:是一个免费提供流行杀毒软件教程、在线学习分享的学习平台!

用PHP与MySQL构建一个数据库驱动的网站(3)

时间:2025/1/11作者:未知来源:盾怪网教程人气:

[摘要]+----------+2 rows in set (0.11 sec)   L服务器使用第一个被称之为mysql的数据库来管理用户及其口令和权限。现在我们暂时不会关心这个数据库,在以后的章节中,我...

+----------+
2 rows in set (0.11 sec)




  L服务器使用第一个被称之为mysql的数据库来管理用户及其口令和权限。现在我们暂时不会关心这个数据库,在以后的章节中,我们会讨论它。第二个叫test是一个数据模块。你可以删除这个数据库,在我们的教程中不会使用到它(我们会自己建立一些数据库)。删除什么东西在MySQL中被称之为“dropping”,要删除test数据库,其正确的命令应该是:

mysql> DROP DATABASE test;



  入了这个命令,并打了回车,MySQL会删除这个数据库,并返回Query OK。注意,并不会提示你诸如“这是否确定”这样的信息。所以你在MySQL输入命令必须十分小心。就象我们在这儿看到的,你可以完全删除数据库--包含它其中的所有信息--仅仅只用一个命令!


  入下一步之前,让我们先来看看MySQL命令行的连接。正如我们已经注意到的,在MySQL中的所有命令都必须以分号(;)结束。如果你忘记了这个分号,MySQL会认为你还没有结束输入你的命令,并会让你这下一行中继续录入:


mysql> SHOW
-> DATABASES;




  L在等待你输入命令中的剩余部分时,提示符会从mysql>改变为->。对于一个长命令,这是很有用的,你可以将你的命令分几行输入。


  途发现你的命令出错了,你可以完全取消当前的命令(译者注:是指尚未执行的命令)并从头来过。要完成这个工作,你只需要输入c并按回车:

mysql> DROP DATABASEcmysql>



  L会完全忽略你刚才输入的命令,并返回到提示符等待你的下一个命令。


  你要退出MySQL客户端程序时,你只需要输入quit或者exit (这两个命令是完全一样的)。这是唯一不用以分号结尾就可以执行的命令。

mysql> quitBye



什么是SQL?

  程中我们用来告诉MySQL去做什么的命令其实是一个叫结构化查询语言(SQL)的规范的一部分。SQL中的命令也被称之为查询(在这篇教程中,我们会交替地采用这两种称呼)。


  实现与绝大多数的数据库的交互的标准语言,所以即使你将来不再使用MySQL,转而使用Microsoft SQL Server,你会发现绝大多数命令是相同的。你必须理解SQL和MySQL的区别。MySQL是你正在使用的数据库服务软件。SQL是你用来实现和数据库的交互的语言。


建立一个数据库

  Web主机提供商已经为你分配了一个用来工作的数据库。你先耐心地等待一下,等一下我们会和你继续讨论下面的问题。如果你是在自己安装的MySQL服务器上工作。执行下面的命令,很容易地你就可以建立一个数据库了:

mysql> CREATE DATABASE jokes;



  库的名字是jokes,这是为了与我们工作的例子一致。其实你可以给你的数据库起任何你自己喜欢的名字。不过,如果你是在Web主机提供商的MySQL服务器上工作,它们可能已经为你建立了一个数据库,你就没法选择数据库的名字了。


  已经有了一个数据库,我们需要告诉MySQL我们想要使用这个数据库。下面这个命令应该也不太难记:

mysql> USE jokes;



  以开始使用你的数据库了。在你在其中添加数据表之前,这个数据库将是空的,我们的第一步工作应该是建立一个数据表来保存我们的笑话。


建立一个数据表

  遇到的SQL命令都是非常简单的,但是因为数据表是比较灵活的,相应地建立它们的命令就要复杂得多了。建立数据表的基本格式是这样的:


mysql> CREATE TABLE <table name;> (
-> <column 1 name;> <col. 1 type;> <col. 1 details;> ,
-> <column 2 name;> <col. 2 type> <col. 2 details;> ,
-> ...
-> );




  现在回到我们的例子“Jokes”表。这个表有三个数据列:ID(一个数字)、JokeText(笑话的正文)和JokeDate(加入的日期)。建立这个表的命令应该是这样的:


mysql> CREATE TABLE Jokes (
-> ID INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
-> JokeText TEXT,
-> JokeDate DATE NOT NULL
-> );



  看上去很复杂,是吧?让我们将它分解一下:

  第一行是比较简单的;它说明我们想要建立一个新的名为Jokes的数据表。

  第二行说明我们需要一个数据列叫ID,这个列的类型应该是一个整数(INT)。这一行还定义了这个数据列的其他一些信息。首先,这一行不允许为空(NOT NULL)。第二,如果你没有为一列指定一个值,MySQL会选择使用一个比当前最大值大的值(AUTO_INCREMENT)。最后,这个数据列还是这数据表的唯一的标识符,所以这个数据列中的所有值都应该是不重复的(PRIMARY KEY)。

  第三行是非常简单的;这说明我们需要一个数据列叫JokeText,这个列的类型应该是一个文本(TEXT)。

  第四行定义了我们的最后一列,列名是JokeDate,这个列的类型是日期型(DATE)这个列也不能为空(NOT NULL)。

  请注意,我们在输入SQL命令时,大小写是完全自由的,但是在一个Unix-based系统下运行的MySQL服务,因为我们必须与MySQL数据目录下的目录和文件一致,当遇到数据库名和表名时,我们必须区分大小写。否则,MySQL是完全对大小写不敏感的,只有一种情况例外,在同一命令中多次出现的表名、列名以及其他名字必须在拼写上完全一致。

  我们还应该注意到,我们为我们建立的每一列指定了一个指定的类型。 ID是一个整型,JokeText是一个文本型,JokeDate是一个日期型。MySQL允许我们为每一个列定义一个类型。 这不仅仅可以帮助你组织数据,而且你可以利用它对数据进行比较(我们在下面会看到)。要想得到一个关于MySQL支持的数据类型的完整的列表,你可以参看MySQL用户手册。

  总之,如果你正确输入了上面的命令,MySQL会返回 Query OK并会为你建立你的第一个数据表。如果你在输入中出了什么错误,MySQL会告诉你输入的语名有问题,而且会给你一些提示,说明什么地方它不能理解。

  对于这样一个复杂的命令,最终只出现Query OK是相当单调的。让我们看看你的新数据表是不是正常地建立了。输入下面的命令:

mysql> SHOW TABLES;


  响应应该是这样的:


+-----------------+

关键词:用PHP与MySQL构建一个数据库驱动的网站(3)




Copyright © 2012-2018 盾怪网教程(http://www.dunguai.com) .All Rights Reserved 网站地图 友情链接

免责声明:本站资源均来自互联网收集 如有侵犯到您利益的地方请及时联系管理删除,敬请见谅!

QQ:1006262270   邮箱:kfyvi376850063@126.com   手机版