搜尋
首頁後端開發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)實現databasequerycachingingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandreduceconnection.4 limitesclection.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

DatabasequeryoptimizationinPHPinvolvesseveralstrategiestoenhanceperformance.1)Selectonlynecessarycolumnstoreducedatatransfer.2)Useindexingtospeedupdataretrieval.3)Implementquerycachingtostoreresultsoffrequentqueries.4)Utilizepreparedstatementsforeffi

簡單指南:帶有PHP腳本的電子郵件發送簡單指南:帶有PHP腳本的電子郵件發送May 12, 2025 am 12:02 AM

phpisusedforsenderemailsduetoitsbuilt-inmail()函數andsupportivelibrariesLikePhpMailerAndSwiftMailer.1)usethemail()functionForbasiceMails,butithasimails.2)butithasimail.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,增強量強制性,可驗證性和MATIALWINABIOS.ItallowSpasspassingDepentenciesLikEdenciesLikedAbaseConnectionStoclasseconnectionStoclasseSasasasasareTers,interitationAseTestingEaseTestingEaseTestingEaseTestingEasingAndScalability。

提高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

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器