四、第一个脚本
如果我告诉您真正难过的一关已经过了,您一定会很高兴。软件的安装过程总是无法预料,因为系统跟系统之间可以说是千差万别。不过您运气不错,
数据库运行起来,
PHP也编译安装完毕,Web服务器也可以正确处理扩展名为.
php3的文件了。
我们下面就开始正式上路,要写第一个脚本
程序了。创建一个文本文件,在其中加入下面的内容:
<>
<>
<?
php$myvar = "Hello World";
echo $myvar;
?>
</body>
</html>
现在,访问相应的URL,例如,http://myserver/test.
php3。您应该可以看到页面中包含“Hello World”的文字。如果您看到的是错误信息,查一下
PHP文档,看看软件设置是否正确无误。
就是这样了!这是您的第一个
PHP程序。如果您查看一下这个页面的HTML源代码,您会发现里面只有Hello World 这样的文字。
那是因为
PHP引擎过滤了文件内容,对其中的代码作了处理,转换成了标准的HTML。
在上面的
程序中您最先注意到的可能是定界符,也就是以<?
php开始的那几行。这个标记说明后面是
PHP代码,而?>表示代码结束。
PHP的强大之处在于,这些代码可以以多种不同方式放在任意位置-我是说任意位置。后面我们会看到一些很有趣的例子,现在我们还是从最简单的开始。如果您愿意,也可以设置
PHP,让它使用短标记,<?和? >,但这与
XML会发生冲突,所以要小心使用。如果您是从
ASP转向
PHP,您甚至可以让
PHP使用<%和%>作为定界符。
您还会注意到每行后面的分号。这些分号称为分隔符,用于分隔不同的指令。您可以把所有的
PHP代码写在一行里,用分隔符把命令分开。但是那样看起来很乱,所以我们在每个分号后面都另起一行。记住,每行最后都要以分号结束。
最后,您会注意到myvar这个字以$符号开头。这个符号告诉
PHP,这是一个变量。我们把“Hello World”赋给变量$myvar。一个变量可以是数字,也可以是数组。不管怎样,所有的变量都是以$符开头。
PHP真正强大之处来源于它的函数。函数,基本上是处理指令序列。如果您把所有的选件都编译进
PHP,总共会有超过700个函数。这些函数可以让您做很多事情。
现在我们再加进一些
MySQL的内容进去。
五、装载
数据库 现在,我们要加入
MySQL的内容了。要想知道
PHP中包含哪些选项,或
服务器方面的一些情况,一种简便的方法是使用函数
phpinfo()。创建一个象下面这样的
程序:
<>
<>
<?
phpphpinfo();
?>
</body>
</html>
保存这个
程序,在浏览器中访问这个文件。您会看到
网页中包含了一些有趣的、有用的信息,象这样。这些信息是有关
服务器、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 < mydb.dump
此时您应该不会遇到什么错误。如果真的出错了,请仔细检查一下是否因上面的文字折行而引起错误。
六、测试
OK,现在我们已经把
数据导入到
数据库中了。现在我们来处理这些
数据。把下面的文字存入一个文件中,把该文件存在Web服务器的文档目录下,后缀名为.
php3。
<>
<>
<?
php$db =
mysql_connect("localhost", "root");
mysql_select_db("mydb",$db);
$result =
mysql_query("SELECT * FROM employees",$db);
printf("First Name: %s<>\n",
mysql_result($result,0,"first"));
printf("Last Name: %s<>\n",
mysql_result($result,0,"last"));
printf("Address: %s<>\n",
mysql_result($result,0,"address"));
printf("Position: %s<>\n",
mysql_result($result,0,"position"));
?>
</body>
</html>
我来解释一下上面的代码。
mysql_connect()函数负责以指定的用户名(本例中用户名是root)连接到指定机器(在本例中机器是本机localhost)上的
MySQL数据库。如果您想指定用户口令,您也可以把它送给这个函数。连接的结果保存在变量$d