搜索
首页后端开发php教程初学入门 PHP 和 MySQL_PHP

  我想要使用PHP和MySQL,但是如何安装和运行呢?什么是最基本的事情我应该知道的,以便让一个简单的PHP - MySQL应用程序工作?
  这是一个基本的教程。没有怪异的代码,只是一些基础。
  多说一句,现在有大量的教程是基于UNIX机器的,这个教程将集中在基于Windows平台上。然而,除了安装部分,有或多或少的针对于Windows的说明外,其它部分对所有的平台都是一样的。
  在这个教程中,我们将一步一步地建立一个小的网站,使用了PHP和MySQL的下面特性:
  1. 查看数据库;
  2. 编辑数据库的记录;
  3. 修改数据库的记录;
  4. 删除数据库的记录。
  我们将同时学习MySQL和PHP,一起去感觉它们。
  第一节 - 收集和建立必要的项目
  好,开始工作。为了开始PHP-MySQL我们需要一些准备:
  1. 运行web服务器;
  2. 增加PHP扩展;
  3. 运行MySQL。
  第一步,得到和安装Web服务器
  让我们假设一下在你的机器上已经有一个运行着的web服务器。在Windows下有几个好用的web服务器应用程序。要注意一件事,为了运行php/mysql你所选的web服务器应当可以支持扩展。
  一个在Windows上最容易安装的服务器是OmniHTTPd(http://www.omnicron.ab.ca/httpd/,它是一个非常好的自由web服务器。
  一旦你从站点上得到了安装文件,双击它并且安装web服务器。如果你在安装时全部选择了使用缺省值,那么你将会把它安装在c:\httpd下。一旦安装成功,安装程序将启动web服务器,带有一个欢迎窗口,在windows的系统托盘中可以看到一个新的图标。
  好了,第一步做完了。
  第二步,下载和安装PHP发行版
  得到PHP Win32发行版很容易:只要去http://www.php.net/download-php.php3,并且选择一个最好的位置就可以了。
  在OmniHTTPd上安装PHP非常简单。
  最先Unzip安装文件到你的硬盘上,比如展开在c:\php。
  拷贝文件'php3.ini-dist'到你的'%WINDOWS'目录下去,并改名'php3.ini'(在Win95/98为c:\windows,在WinNT/Win2k为c:\winnt)。
  按下面编辑php3.ini文件:
  改变'extension_dir'设置为你的PHP安装目录(c:\php),或存放'php3_*.dll'的目录。
  选择想在PHP启动时装入的模块。你应该将'extension=php3_*.dll'行的注释去掉来装入这些模块(一定要确认去掉了extension=php3_mysql.dll的注释)。一些模块要求有额外的库安装在你的系统上才能正常工作。
  PHP问答集(http://www.php.net/FAQ.php3)有更多关于如何得到支持库的信息。你可以通过使用:dl("php_*.dll")动态地装入一个模块。
  PHP扩展库以'php3_'为前缀。这个可以防止在PHP扩展与它们的支持库之间发生混淆。
  现在跟着简单的步骤配置OmniHTTPd:
  在系统托盘中右击蓝色的OmniHTTPd图标,选项属性(Properties)项;
  点击Web Server Global Settings项;
  点中'External'tab标签。现在,在"Virtual"域中输入".php3",在"actual"域中输入"c:\php\php.exe",然后单击"Add"。
  选择Mime tab标签并且在"Vritual"中输入"wwwserver/stdcgi",在"Actual"中输入".php3",并单击"Add"。
  单击 OK。
  在同一个窗体中选择Default Virtual Settings;
  现在单击Server tab标签;
  在"Default Index"域中输入"Index.php3"(用逗号分隔)。这将告诉web服务器也可以识别index.php3文件。
  单击 OK。
  好,足够了。让我们测试一下PHP是否在工作:
  创建一个名为index.php3的文本文件,写入下面的文本:
<font color="#000000"> <font color="#0000BB"></font><font color="#007700"> <br><br>echo </font><font color="#DD0000">"I made it!\"; <br><br>?></font> </font>
  启动你的浏览器,并指到localhost。你应该在屏幕上得到"I made it!"。
  下面,得到和安装MySQL:
  去http://www.mysql.com/download_win.html,下载MySQL-Win32发行版,将zip文件解压到一个临时目录并且运行安装程序(setup.exe)。
  如果你选择了缺省的典型安装,所有的MySQL文件将会安装到c:\mysql目录下。
  现在,跟着以下步骤,每一步都要执行正确。
  进行一些测试:
  首先,你要先运行mysqld-shareware.exe守护程序,它位于c:\mysql\bin下。你可以看到一个dos窗口,并在几秒钟后关闭。如果没有显示错误信息,MySQLd就已经运行了。
  如果想检查一下MySQL,只要运行c:\mysql\bin\mysql。你将会看到有"mysql>"提示符的终端窗口。很好,我们可以同MySQL服务器进行对话了。
  第二部分 -- 创建和操纵一个MySQL数据库:
  首先我们需要创建要使用的数据库和表。数据库起名为"example",表名为"tbl",有以下字段:识别号, 名,姓和信息。要通过mysql终端完成建库和定义表的工作,只要双击或运行c:\mysql\bin\mysql.exe。
  如果要看在MySQL中已经定义了哪些表,可以使用(注意mysql>是终端提示符):
Mysql> show databases;
  这个命令可能显示如下信息:

----------
| Database |
----------
| mysql |
| test |
----------
2 rows in set (0.01 sec)
  为了定义一个新的数据库(example),键入:
Mysql> create database example;
  你将会看到一个回答,如:
Query OK, 1 row affected (0.17 sec)
  很发,我们现在有了一个新数据库了。现在我们可以在库中建立一个新表,但首先我们需要先选中新的数据库:
Mysql> use example;
  回答应该是:
Database changed
  现在我们可以建表了,有如下字段:
  索引号 - 整数
  用户名 - 最大长度为30的字符串
  用户姓 - 最大长度为50的字符串
  自由信息 - 最大长度为100的字符串
  在MySQL提示符下键入下面的命令来创建表:
MySQL> create table tbl (idx integer(3), UserName varchar(30), LastName varchar(50), FreeText varchar(100));
  回答应该是:
Query OK, 0 rows affected (0.01 sec)
  好,让我们看一下从MySQL提示符下看表是什么样子的,键入命令:
MySQL> show columns from tbl;
  我们将得到下面的结果:

---------- -------------- ------ ----- --------- -------
| Field | Type | Null | Key | Default | Extra |
---------- -------------- ------ ----- --------- -------
| idx | int(3) | YES | | NULL | |
| UserName | varchar(30) | YES | | NULL | |
| LastName | varchar(50) | YES | | NULL | |
| FreeText | varchar(100) | YES | | NULL | |
---------- -------------- ------ ----- --------- -------
4 rows in set (0.00 sec)

  在这里,我们可以看到刚创建的表"tbl"的内容。
  现在让我们看一下表中有什么内容。键入下面的命令:
MySQL> select * from tbl;
  这个命令是用来显示表"tbl"中的所有数据的。输出可能是:
Empty set (0.07 sec)
  之所以得到这个结果,是因为我们还没有在表中插入任何数据。让我们往表中插入一些数据,键入:
MySQL> insert into tbl values (1,'Rafi','Ton','Just a test');
Query OK, 1 row affected (0.04 sec)
  如上所见,我们插入到表中的值是按照前面我们定义表的顺序,因为使用的是缺省的顺序。我们可以设定数据的顺序,语法如下:
MySQL> insert into tbl (idx,UserName,LastName,FreeText) values (1,'Rafi','Ton','Just a test');
  好,现在我们可以再看一下表中的内容:
MySQL> select * from tbl;
  这次的结果是:

------ ---------- ---------- -------------
| idx | UserName | LastName | FreeText |
------ ---------- ---------- -------------
| 1 | Rafi | Ton | Just a test |
------ ---------- ---------- -------------
1 row in set (0.00 sec)
  现在我们可以看到表的结构和每一个单元格的内容。
  现在我们想删除数据。为了实现我们应该键入:
MySQL> delete from tbl where idx=1 limit 1; Query OK, 1 row affected (0.00 sec)
   好,给出一些解释。我们正在告诉MySQL从"tbl"表中删除记录,删除那些idx字段值为1的记录,并且只限制删除一条记录。如果我们不限制删除记录数为1,那么所有idx为1的记录都将被删除(在这个例子中我们只有一条记录,但是虽然如此,我只是想让这一点更加清楚)。
  不幸的是,我们又一次得到了一个空表,所以让我们再输进去:
MySQL> insert into tbl values (1,'Rafi','Ton','Just a test');
Query OK, 1 row affected (0.04 sec)
  另一件可以做的事是,修改指定字段的内容,使用"update"命令:
MySQL>update tbl set UserName='Berber' where UserName='Rafi';
Query OK, 1 row affected (0.01 sec)
Rows matched: 1 Changed: 1 Warnings: 0
  这个命令将搜索所有UserName为"Rafi"的记录,并将它改为"Berber"。注意,set部分和where部分不一定要一样。我们可以索搜一个字段但是改变另一个字段。而且,我们可以执行两个或更多条件的搜索。
MySQL>update tbl set UserName='Rafi' where UserName='Berber' and LastName='Ton';
Query OK, 1 row affected (0.04 sec)
  这个查询搜索了两个字段,改变了UserName的值。
  第三部分 - 组合PHP与MySQL
  在这个部分里,我们将建立一个建单的基于PHP的web站点,用来控制前面所建的MySQL的表。
  我们将建立下面的站点结构(假设你已经知道一些基本的HTML的知识):
  1. index.php3 用于前端查看表
  2. add.php3 用于往表中插入数据
  3. Modify.php3 用于修改表中的记录
  4. del.php3 用于删除表中的记录
  首先,我们想查看一下数据库:
  看一下下面的脚本。
<font color="#000000"> <font color="#0000BB">Index</font><font color="#007700">.</font><font color="#0000BB">php3</font><font color="#007700">: <br><br><font color="#0000BB">html</font><font color="#007700">> <br><br><font color="#0000BB">head</font><font color="#007700">><font color="#0000BB">title</font><font color="#007700">></font><font color="#0000BB">Web Database Sample Index</font><font color="#007700"></font><font color="#0000BB">title</font><font color="#007700">> <br><br></font><font color="#0000BB">head</font><font color="#007700">> <br><br><font color="#0000BB">body bgcolor</font><font color="#007700">=</font><font color="#FF8000">#ffffff> <br><br></font><font color="#007700"><font color="#0000BB">h2</font><font color="#007700">></font><font color="#0000BB">Data from tbl</font><font color="#007700"></font><font color="#0000BB">h2</font><font color="#007700">> <br><br> <br><br></font><font color="#0000BB">mysql_connect</font><font color="#007700">() or die (</font><font color="#DD0000">"Problem connecting to DataBase\"); <br><br>$query = \"select * from tbl\"; <br><br>$result = mysql_db_query(\"example\", $query); <br><br>if ($result) { <br><br>echo \"Found these entries in the database:<br><p></p>\"; <br><br>echo \"<table width="90%" align="center" border="1"> <tr> <br><br><td align="center" bgcolor="#00FFFF">User Name</td> <br><br><td align="center" bgcolor="#00FFFF">Last Name</td> <br><br><td align="center" bgcolor="#00FFFF">Domain Name</td> <br><br><td align="center" bgcolor="#00FFFF">Request Date</td> <br><br> </tr>\"; <br><br>while ($r = mysql_fetch_array($result)) <br><br>{ <br><br>$idx = $r[\"idx\"]; <br><br>$user = $r[\"UserName\"]; <br><br>$last = $r[\"LastName\"]; <br><br>$text = $r[\"FreeText\"]; <br><br>echo \"<tr> <br><br><td>$idx</td> <br><br><td>$user</td> <br><br><td>$last</td> <br><br><td>$text</td> <br><br> </tr>\"; <br><br>} <br><br>echo \"</table>\"; <br><br>} <br><br>else <br><br>{ <br><br>echo \"No data.\"; <br><br>} <br><br>mysql_free_result($result); <br><br>include ('links.x'); <br><br>?> <br><br></font></font></font></font></font></font></font>

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
如何使PHP应用程序更快如何使PHP应用程序更快May 12, 2025 am 12:12 AM

tomakephpapplicationsfaster,关注台词:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

PHP性能优化清单:立即提高速度PHP性能优化清单:立即提高速度May 12, 2025 am 12:07 AM

到ImprovephPapplicationspeed,关注台词:1)启用opcodeCachingwithapCutoredUcescriptexecutiontime.2)实现databasequerycachingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandredececonnection.4 limitsclection.4.4

PHP依赖注入:提高代码可检验性PHP依赖注入:提高代码可检验性May 12, 2025 am 12:03 AM

依赖注入(DI)通过显式传递依赖关系,显着提升了PHP代码的可测试性。 1)DI解耦类与具体实现,使测试和维护更灵活。 2)三种类型中,构造函数注入明确表达依赖,保持状态一致。 3)使用DI容器管理复杂依赖,提升代码质量和开发效率。

PHP性能优化:数据库查询优化PHP性能优化:数据库查询优化May 12, 2025 am 12:02 AM

databasequeryOptimizationinphpinvolVolVOLVESEVERSEVERSTRATEMIESOENHANCEPERANCE.1)SELECTONLYNLYNESSERSAYCOLUMNSTORMONTOUMTOUNSOUDSATATATATATATATATATATRANSFER.3)

简单指南:带有PHP脚本的电子邮件发送简单指南:带有PHP脚本的电子邮件发送May 12, 2025 am 12:02 AM

phpisusedforsenderemailsduetoitsbuilt-inmail()函数andsupportiveLibrariesLikePhpMailerandSwiftMailer.1)usethemail()functionforbasicemails,butithasimails.2)butithasimimitations.2)

PHP性能:识别和修复瓶颈PHP性能:识别和修复瓶颈May 11, 2025 am 12:13 AM

PHP性能瓶颈可以通过以下步骤解决:1)使用Xdebug或Blackfire进行性能分析,找出问题所在;2)优化数据库查询并使用缓存,如APCu;3)使用array_filter等高效函数优化数组操作;4)配置OPcache进行字节码缓存;5)优化前端,如减少HTTP请求和优化图片;6)持续监控和优化性能。通过这些方法,可以显着提升PHP应用的性能。

PHP的依赖注入:快速摘要PHP的依赖注入:快速摘要May 11, 2025 am 12:09 AM

依赖性注射(DI)InphpisadesignPatternthatManages和ReducesClassDeptions,增强量产生性,可验证性和Maintainability.itallowspasspassingDepentenciesLikEdenceSeconnectionSeconnectionStoclasseconnectionStoclasseSasasasasareTers,interitationApertatingAeseritatingEaseTestingEasingEaseTeStingEasingAndScalability。

提高PHP性能:缓存策略和技术提高PHP性能:缓存策略和技术May 11, 2025 am 12:08 AM

cachingimprovesphpermenceByStorcyResultSofComputationsorqucrouctationsorquctationsorquickretrieval,reducingServerLoadAndenHancingResponsetimes.feftectivestrategiesinclude:1)opcodecaching,whereStoresCompiledSinmememorytssinmemorytoskipcompliation; 2)datacaching datacachingsingMemccachingmcachingmcachings

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具