Home >Backend Development >PHP Tutorial >PHP/MySQL Three-Day Pass - Day One (Two)_PHP Tutorial
四、第一个脚本
如果我告诉您真正难过的一关已经过了,您一定会很高兴。软件的安装过程总是无法预料,因为系统跟系统之间可以说是千差万别。不过您运气不错,数据库运行起来,PHP也编译安装完毕,Web服务器也可以正确处理扩展名为.php3的文件了。
我们下面就开始正式上路,要写第一个脚本程序了。创建一个文本文件,在其中加入下面的内容:
$#@60;html$#@62; $#@60;body$#@62; $#@60;?php $myvar = "Hello World"; echo $myvar; ?$#@62; $#@60;/body$#@62; $#@60;/html$#@62; |
现在,访问相应的URL,例如,http://myserver/test.php3。您应该可以看到页面中包含“Hello World”的文字。如果您看到的是错误信息,查一下PHP文档,看看软件设置是否正确无误。
就是这样了!这是您的第一个PHP程序。如果您查看一下这个页面的HTML源代码,您会发现里面只有Hello World 这样的文字。
那是因为PHP引擎过滤了文件内容,对其中的代码作了处理,转换成了标准的HTML。
在上面的程序中您最先注意到的可能是定界符,也就是以$#@60;?php开始的那几行。这个标记说明后面是PHP代码,而?$#@62;表示代码结束。PHP的强大之处在于,这些代码可以以多种不同方式放在任意位置 - 我是说任意位置。后面我们会看到一些很有趣的例子,现在我们还是从最简单的开始。如果您愿意,也可以设置PHP,让它使用短标记,$#@60;?和?$#@62;,但这与XML会发生冲突,所以要小心使用。如果您是从ASP转向PHP,您甚至可以让PHP使用$#@60;%和%$#@62;作为定界符。
您还会注意到每行后面的分号。这些分号称为分隔符,用于分隔不同的指令。您可以把所有的PHP代码写在一行里,用分隔符把命令分开。但是那样看起来很乱,所以我们在每个分号后面都另起一行。记住,每行最后都要以分号结束。
最后,您会注意到myvar这个字以$符号开头。这个符号告诉PHP,这是一个变量。我们把“Hello World”赋给变量$myvar。一个变量可以是数字,也可以是数组。不管怎样,所有的变量都是以$符开头。 <
PHP真正强大之处来源于它的函数。函数,基本上是处理指令序列。如果您把所有的选件都编译进PHP,总共会有超过700个函数。这些函数可以让您做很多事情。
现在我们再加进一些MySQL的内容进去。
五、装载数据库
现在,我们要加入MySQL的内容了。要想知道PHP中包含哪些选项,或服务器方面的一些情况,一种简便的方法是使用函数phpinfo()。创建一个象下面这样的程序:
$#@60;html$#@62; $#@60;body$#@62; $#@60;?php phpinfo(); ?$#@62; $#@60;/body$#@62; $#@60;/html$#@62; |
保存这个程序,在浏览器中访问这个文件。您会看到网页中包含了一些有趣的、有用的信息,象这样。这些信息是有关服务器、Web服务器内部环境变量、PHP中包含的选项,等等。在第一段Extensions中,找到以MySQL开头的一行。如果没有找到,那说明MySQL支持选项并没有编译进PHP。您可以再检查一下安装步骤,查阅一下PHP文档,看您是否漏掉了什么。
如果找到了MySQL那一行,那您可以继续了。
从MySQL数据库中读取数据之前,我们得先往数据库里放一些数据。在现在这一阶段,还没有一个简便的方法来做这件事情。大多数的PHP程序都带有一个数据文件,该文件包含一些数据来创建并激活MySQL数据库。这个过程不在本教程范围之内,所以让我来替您做这件事情吧。
MySQL使用它自己的用户权限表。在安装时,会创建一个默认的用户(root),该用户是没有口令的。数据库管理员可以根据需要来增加用户并赋予用户各种不同的权限,但这项工作完全可以另写一本书了,所以我们只使用root用户。如果您自己管理服务器和数据库,为root用户分配一个口令是很重要的。
总之,我们还是接着说数据库吧。对Win32用户来说,很对不起,不过您要在DOS下做些工作。您不得不使用DOS窗口,或者在“执行”窗口中键入所有命令。别忘了,输入命令时要带上MySQL/bin的目录名。Unix用户可以在MySQL的bin目录下输入命令,但命令必须以./开头,才能让程序运行起来。
我们要做的第一件事情是实际创建出数据库。在命令行下,键入下列命令:
mysqladmin -u root create mydb
这样就创建了一个名为“mydb”的数据库。-u选项告诉MySQL我们使用的是root用户。
下一步,我们要加入一些数据,这里我们用的示例数据是大家都喜欢用的员工数据库。我们将会用到我前面提到过的数据文件。如果您想在这方面多了解一些,可以查阅MySQL所带的手册或访问 http://www.turbolift.com/mysql/网站。
把下面的文字复制到一个文件中,把该文件存在MySQL的bin目录下(我假定文件名是mydb.dump)。
CREATE TABLE employees ( id tinyint(4) DEFAULT 0 NOT NULL AUTO_INCREMENT, first varchar(20), last varchar(20), address varchar(255), position varchar(50), PRIMARY KEY (id), UNIQUE id (id));INSERT INTO employees VALUES (1,Bob,Smith, 128 Here St, Cityname,Marketing Manager); INSERT INTO employees VALUES (2,John,Roberts,45 There St , Townville,Telephonist); INSERT INTO employees VALUES (3,Brad,Johnson,1/34 Nowhere Blvd, Snowston,Doorman); |
如果文字是折行的,请确保每一个INSERT语句都是另起一行的。现在,我们要把数据加入到mydb数据库中了。在命令行下,键入下面的命令:
mysql -u root mydb $#@60; mydb.dump
此时您应该不会遇到什么错误。如果真的出错了,请仔细检查一下是否因上面的文字折行而引起错误。
六、测试
OK,现在我们已经把数据导入到数据库中了。现在我们来处理这些数据。把下面的文字存入一个文件中,把该文件存在Web服务器的文档目录下,后缀名为.php3。
$#@60;html$#@62; $#@60;body$#@62; $#@60;?php $db = mysql_connect("localhost", "root"); mysql_select_db("mydb",$db); $result = mysql_query("SELECT * FROM employees",$db); printf("First Name: %s$#@60;br$#@62; ", mysql_result($result,0,"first")); printf("Last Name: %s$#@60;br$#@62; ", mysql_result($result,0,"last")); printf("Address: %s$#@60;br$#@62; ", mysql_result($result,0,"address")); printf("Position: %s$#@60;br$#@62; ", mysql_result($result,0,"position")); ?$#@62; $#@60;/body$#@62; $#@60;/html$#@62; |
Let me explain the above code. The mysql_connect() function is responsible for connecting to the MySQL database on the specified machine (in this case the machine is localhost) with the specified user name (in this case the user name is root). If you want to specify a user password, you can also pass it to this function. The result of the connection is saved in the variable $db.
Then, the mysql_select_db() function tells PHP that the database we want to read is mydb. We can connect to multiple databases on multiple machines at the same time in the program, but currently we are limited to connecting to one database.
Next, the mysql_query() function completes the most complex part. Using the connection result identifier just obtained, this function sends a row of SQL statements to the MySQL server for processing. The returned result is stored in the variable $result.
Finally, the mysql_result() function displays the values of each field obtained by the SQL query command. Using the variable $result, we can find the first record, the record number is 0, and display the values of each field in it.
If you have never used Perl or C language before, the syntax format of the printf function will seem strange. In each line of the program above, %s represents which variable in the second part of the expression (for example, mysql_result($result,0,"position")) should be displayed as a string.
That’s it for this lesson. We have successfully compiled, installed and set up MySQL and PHP, and run a simple program to read information from the database. In the second lesson, we will do some more complex work to display data from multiple rows and even exchange data with the database.
Keep up the good work!