PHP_MySQL教程-第一天
程序员文章站
2022-09-08 18:19:28
第一页 php/mysql简介 您应该听说过开放源代码软件(oss),除非最近六到八个月来您一直住在火星上。这场运动有着巨大的冲击力,已引起一些大公司...
第一页 php/mysql简介
您应该听说过开放源代码软件(oss),除非最近六到八个月来您一直住在火星上。这场运动有着巨大的冲击力,已引起一些大公司的注意。象oralce、informix,还有多家公司都开始把他们的主力数据库产品移植到oss的产物之一 - linux操作系统上。
如果您有足够的技术力量,拥有一个复杂庞大的关系数据库系统(rdbms)则是如虎添翼。但是也许您对数据库还刚刚入门,您刚刚读了jay的文章,决定自己也来搞一个数据驱动的网站。可是您也许会发现您缺乏必要的资源来运行asp服务器或昂贵的数据库系统(您也不需要这些东西)。您需要一些免费的、支持unix的东西。
那么我建议您使用php和mysql。这两样东西加在一起,对于开发数据驱动的网站这项工作而言,真是最佳组合。其实用不着我多费唇舌解释。一项由netcraft组织的非官方调查显示,应用php的主机数目由1998年6月的7,500台跃升至1999年3月的410,000台。不错吧?这两种软件的组合还在webcon98大会上赢得了年度数据库产品大奖,还得了一座漂亮的奖杯。
mysql是一个小巧灵珑的数据库服务器软件,对于小型(当然也不一定很小)应用系统是非常理想的。除了支持标准的ansi sql语句,它还支持多种平台,而在unix系统上该软件支持多线程运行方式,从而能获得相当好的性能。对于不使用unix的用户,它可以在windows nt系统上以系统服务方式运行,或者在windows 95/98系统上以普通进程方式运行。
php是一种服务器端解释的脚本语言。如果你接触过asp的话,那么您对于在html页面中嵌入代码应该是比较熟悉了。php代码在服务器一端被解释转变成普通的html页面内容,送给浏览器一端。这种模式使得我们可以用它来完成相当复杂的功能。
除了免费这一点(当然,mysql也有一些使用许可方面的限制),php-mysql的组合还可以跨平台运行,这意味着您可以在windows上开发,然后在unix平台上运行。另外,php也能作为标准的cgi进程来运行,此时它是一个独立的脚本解释器,或者是apache的一个嵌入模块。
如果您有兴趣使用其他数据库服务器的话,php也支持informix、oracle、sybase、solid和postgresql ,以及通用的odbc。
php支持internet开发的一些前沿技术。这些技术包括身份认证、xml、动态图象生成、wddx、共享内存,以及动态pdf文档等等,不一而足。如果您还不满意的话,php是很容易扩展的,所以只要您有编程能力,您尽可以自己大展身手一番。
最后要说的是,两种软件都是大量程序员协同开发的,因此文档及邮件列表等支持方式很多。程序错误的修正很快,而如果您要求加入新功能的话,总会有人考虑您的要求,并且在可行性足够高的前提下加以实现。
说得够多了!我们来看看这篇教程里都有些什么内容吧。
第一课讲的是在unix和windows环境下安装这两个软件。如果您不太关心这个问题(也许您是在isp的服务器上开发),您可以直接跳到第一个示例程序,从那里开始您的奇妙之旅。
在第二课里,我们要学习一些更加复杂的脚本功能,比如循环、处理用户输入,以及与数据库交换数据等等。
第三课要讲的是确认功能,以及如何使您的脚本程序清晰简练。
我们开始吧。
第四页 第一个脚本
如果我告诉您真正难过的一关已经过了,您一定会很高兴。软件的安装过程总是无法预料,因为系统跟系统之间可以说是千差万别。不过您运气不错,数据库运行起来,php也编译安装完毕,web服务器也可以正确处理扩展名为.php3的文件了。
我们下面就开始正式上路,要写第一个脚本程序了。创建一个文本文件,在其中加入下面的内容:
<html>
<body>
<?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()。创建一个象下面这样的程序:
<html>
<body>
<?php
phpinfo();
?>
</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
此时您应该不会遇到什么错误。如果真的出错了,请仔细检查一下是否因上面的文字折行而引起错误。
net 第六页 测试
ok,现在我们已经把数据导入到数据库中了。现在我们来处理这些数据。把下面的文字存入一个文件中,把该文件存在web服务器的文档目录下,后缀名为.php3。
<html>
<body>
<?php
$db = mysql_connect("localhost", "root");
mysql_select_db("mydb",$db);
$result = mysql_query("select * from employees",$db);
printf("first name: %s<br>n", mysql_result($result,0,"first"));
printf("last name: %s<br>n", mysql_result($result,0,"last"));
printf("address: %s<br>n", mysql_result($result,0,"address"));
printf("position: %s<br>n", mysql_result($result,0,"position"));
?>
</body>
</html>
我来解释一下上面的代码。mysql_connect()函数负责以指定的用户名(本例中用户名是root)连接到指定机器(在本例中机器是本机localhost)上的mysql数据库。如果您想指定用户口令,您也可以把它送给这个函数。连接的结果保存在变量$db中。
随后,mysql_select_db()函数告诉php,我们要读取的数据库是mydb。我们可以在程序中同时连接到多台机器上的多个数据库,但目前我们还是限于连接一个数据库。
接下来,mysql_query()函数完成最复杂的部分。利用刚才得到的连接结果标识,该函数把一行sql语句送给mysql服务器去处理。返回的结果保存在变量$result中。
最后,mysql_result()函数显示sql查询命令所得到的各个字段的值。利用变量$result,我们就可以找到第一条记录,记录号是0,并将其中各字段的值显示出来。
如果您以前没用过perl或c语言,那么printf函数的语法格式会显得很奇怪。在上面的每一行程序中,%s代表表达式第二部分中的那个变量(例如,mysql_result($result,0,"position"))应该以字符串的形式显示出来。想更深入了解printf,请参阅php文档。
这一课我们就讲到这里了。我们已经成功地编译、安装和设置了mysql和php,并且运行了一个简单的程序来读取数据库中的信息。在 第二课里,我们会做一些更复杂的工作,来显示多行记录的数据,甚至与数据库互相交换数据。
您应该听说过开放源代码软件(oss),除非最近六到八个月来您一直住在火星上。这场运动有着巨大的冲击力,已引起一些大公司的注意。象oralce、informix,还有多家公司都开始把他们的主力数据库产品移植到oss的产物之一 - linux操作系统上。
如果您有足够的技术力量,拥有一个复杂庞大的关系数据库系统(rdbms)则是如虎添翼。但是也许您对数据库还刚刚入门,您刚刚读了jay的文章,决定自己也来搞一个数据驱动的网站。可是您也许会发现您缺乏必要的资源来运行asp服务器或昂贵的数据库系统(您也不需要这些东西)。您需要一些免费的、支持unix的东西。
那么我建议您使用php和mysql。这两样东西加在一起,对于开发数据驱动的网站这项工作而言,真是最佳组合。其实用不着我多费唇舌解释。一项由netcraft组织的非官方调查显示,应用php的主机数目由1998年6月的7,500台跃升至1999年3月的410,000台。不错吧?这两种软件的组合还在webcon98大会上赢得了年度数据库产品大奖,还得了一座漂亮的奖杯。
mysql是一个小巧灵珑的数据库服务器软件,对于小型(当然也不一定很小)应用系统是非常理想的。除了支持标准的ansi sql语句,它还支持多种平台,而在unix系统上该软件支持多线程运行方式,从而能获得相当好的性能。对于不使用unix的用户,它可以在windows nt系统上以系统服务方式运行,或者在windows 95/98系统上以普通进程方式运行。
php是一种服务器端解释的脚本语言。如果你接触过asp的话,那么您对于在html页面中嵌入代码应该是比较熟悉了。php代码在服务器一端被解释转变成普通的html页面内容,送给浏览器一端。这种模式使得我们可以用它来完成相当复杂的功能。
除了免费这一点(当然,mysql也有一些使用许可方面的限制),php-mysql的组合还可以跨平台运行,这意味着您可以在windows上开发,然后在unix平台上运行。另外,php也能作为标准的cgi进程来运行,此时它是一个独立的脚本解释器,或者是apache的一个嵌入模块。
如果您有兴趣使用其他数据库服务器的话,php也支持informix、oracle、sybase、solid和postgresql ,以及通用的odbc。
php支持internet开发的一些前沿技术。这些技术包括身份认证、xml、动态图象生成、wddx、共享内存,以及动态pdf文档等等,不一而足。如果您还不满意的话,php是很容易扩展的,所以只要您有编程能力,您尽可以自己大展身手一番。
最后要说的是,两种软件都是大量程序员协同开发的,因此文档及邮件列表等支持方式很多。程序错误的修正很快,而如果您要求加入新功能的话,总会有人考虑您的要求,并且在可行性足够高的前提下加以实现。
说得够多了!我们来看看这篇教程里都有些什么内容吧。
第一课讲的是在unix和windows环境下安装这两个软件。如果您不太关心这个问题(也许您是在isp的服务器上开发),您可以直接跳到第一个示例程序,从那里开始您的奇妙之旅。
在第二课里,我们要学习一些更加复杂的脚本功能,比如循环、处理用户输入,以及与数据库交换数据等等。
第三课要讲的是确认功能,以及如何使您的脚本程序清晰简练。
我们开始吧。
第四页 第一个脚本
如果我告诉您真正难过的一关已经过了,您一定会很高兴。软件的安装过程总是无法预料,因为系统跟系统之间可以说是千差万别。不过您运气不错,数据库运行起来,php也编译安装完毕,web服务器也可以正确处理扩展名为.php3的文件了。
我们下面就开始正式上路,要写第一个脚本程序了。创建一个文本文件,在其中加入下面的内容:
复制代码 代码如下:
<html>
<body>
<?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()。创建一个象下面这样的程序:
复制代码 代码如下:
<html>
<body>
<?php
phpinfo();
?>
</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
此时您应该不会遇到什么错误。如果真的出错了,请仔细检查一下是否因上面的文字折行而引起错误。
net 第六页 测试
ok,现在我们已经把数据导入到数据库中了。现在我们来处理这些数据。把下面的文字存入一个文件中,把该文件存在web服务器的文档目录下,后缀名为.php3。
复制代码 代码如下:
<html>
<body>
<?php
$db = mysql_connect("localhost", "root");
mysql_select_db("mydb",$db);
$result = mysql_query("select * from employees",$db);
printf("first name: %s<br>n", mysql_result($result,0,"first"));
printf("last name: %s<br>n", mysql_result($result,0,"last"));
printf("address: %s<br>n", mysql_result($result,0,"address"));
printf("position: %s<br>n", mysql_result($result,0,"position"));
?>
</body>
</html>
我来解释一下上面的代码。mysql_connect()函数负责以指定的用户名(本例中用户名是root)连接到指定机器(在本例中机器是本机localhost)上的mysql数据库。如果您想指定用户口令,您也可以把它送给这个函数。连接的结果保存在变量$db中。
随后,mysql_select_db()函数告诉php,我们要读取的数据库是mydb。我们可以在程序中同时连接到多台机器上的多个数据库,但目前我们还是限于连接一个数据库。
接下来,mysql_query()函数完成最复杂的部分。利用刚才得到的连接结果标识,该函数把一行sql语句送给mysql服务器去处理。返回的结果保存在变量$result中。
最后,mysql_result()函数显示sql查询命令所得到的各个字段的值。利用变量$result,我们就可以找到第一条记录,记录号是0,并将其中各字段的值显示出来。
如果您以前没用过perl或c语言,那么printf函数的语法格式会显得很奇怪。在上面的每一行程序中,%s代表表达式第二部分中的那个变量(例如,mysql_result($result,0,"position"))应该以字符串的形式显示出来。想更深入了解printf,请参阅php文档。
这一课我们就讲到这里了。我们已经成功地编译、安装和设置了mysql和php,并且运行了一个简单的程序来读取数据库中的信息。在 第二课里,我们会做一些更复杂的工作,来显示多行记录的数据,甚至与数据库互相交换数据。
下一篇: 不会印真钞,只能印假的了
推荐阅读
-
windows phone 配置PhoneGap开发环境(wp7 phonegap 开发环境)图文教程
-
i7-4770K怎么搭配装机?2015组装电脑装机教程图文详解
-
宏基4750g怎么拆机?宏基4750g拆机清灰的图文教程
-
Macbook怎么清理系统垃圾? Macbook日常维护教程
-
神舟战神t6ti笔记本如何安装win7系统 神舟战神t6ti笔记本安装win7系统图文教程
-
BarTender怎么给二维码导入logo图表? BarTender数据库字段动态插入图片的教程
-
win10系统怎么连接游戏手柄?win10校准和设置游戏手柄的教程
-
Apple Watch怎么升级watchOS 2?苹果手表升级watchOS 2图文教程
-
MacBook笔记本怎么剪辑视频? QuickTime Player剪辑视频的教程
-
如何将PDF文件转换成txt? PDF转换成txt图文教程