検索
ホームページバックエンド開発PHPチュートリアルPHP と MySQL の基本チュートリアル (1)

この記事の内容は PHP と MySQL の基本的なチュートリアルです。必要な方は参考にしていただければ幸いです。

HTML、php、MySQL 間の相互作用

なぜデータベースを使用する必要があるのですか?

ワールド ワイド ウェブ (WWW) は単なる情報の場所ではありません。何かあれば、ウェブサイトを作成して世界中の人々と共有してください。ただし、これは簡単な作業ではありません。ウェブサイトがどんどん大きくなると、次のような問題に遭遇する可能性があります:

ウェブサイトに含まれているものが多すぎて、訪問者が欲しいものをすぐに手に入れることができません。この問題は、Web サイトにとってある程度致命的です。
訪問者はあなたに情報を提供したいと考えており、この情報は後で使用できるように保存する必要があります。

上記の 2 つの問題は両方ともデータベースを通じて解決できます。

WWW の世界では、データベースがいたるところにあります。 Yahoo!、Amazon、eBay のような大規模なものから、単純な掲示板のような小規模なものまで、データベースが使用されていることがわかります。データベースはすべての高度なアプリケーションの基盤であるとさえ言えます。

PHP と MYSQL を使用する理由

私の知る限り、ほとんどすべての主要な商用 Web サイトのデータベースは SQL に基づいています。おそらくこれらの中で最も人気があるのは Oracle です。強力で、もちろん高価です。 SQLはアプリケーションではなく、Structured Query Language(Structured Query Language)の略称で、データベースの操作や問い合わせに使用されます。

近年、多くの企業が「オープンコード」SQL アプリケーションを開発していますが、おそらく最も有名なのは MySQL です。無料なだけではなく、一般的な中小規模のデータベースアプリケーションであれば、Oracleと比べても遜色ないパフォーマンスを発揮します。

Web サイトで MySQL を実行するには、データベースと対話するためのスクリプト言語が必要です。以前は Perl が最も人気がありました。しかし、今では PHP の方が優れているようです。何が違うのかと聞かないでください?? 私は以前は Perl を使用していましたが、問題なく動作していましたが、今では誰もが PHP を好むようです。人気の理由は確かにあります。

必要なソフトウェア

この部分の内容は、ChinaByte Network Academyの以前の記事で紹介されています。読者は、「win98 用のローカル PHP 開発のセットアップ」の記事を参照してください。ここではこれ以上の詳細は説明しません。

HTML と PHP

PHP がどのように動作するかを見てみましょう。以下のコードを見てください:

< html> 
< body> 
< ?php 
PRint "Hello, world."; 
?> 
< /body> 
< /html>

このページがリクエストされると、ブラウザに「Hello, world」が表示されます。

ご覧のとおり、PHP スクリプトは HTML ファイルに埋め込まれています。 「 」で終わります。それだけでなく、PHP スクリプトに HTML タグを埋め込むこともできます:

< ?php 
print "< html>"; 
print "< body>"; 
print "Hello, world."; 
print "< /body>"; 
print "< /html>"; 
?>

2 つの方法は同じ目標を達成し、効果も同じです。ただし、特殊な場合には、いずれかを選択した方が便利な場合があります。

PHP の prints ステートメント

PHP と HTML の間の最も単純な対話は、print ステートメントによって実現されます。

< ?php 
print "Hello, world."; 
?>

print は最も単純で最もよく使用される関数で、ブラウザー ウィンドウにテキストを表示するために使用されます。echo 関数はprint と似ていますが、表示する複数の内容を「,」で区切ることができるため、文字列定数と変数を混在して表示する場合に便利です。

数値の出力をフォーマットするために使用される printf 関数もあります。数値は整数または科学的表記法で表示できます。

これらの関数では、括弧の使用法が異なります:

echo には括弧があってはなりません
printf にはオプションの
print が必要です

文字列または数値を表示するには 非常に簡単で、print の後に変数名または定数を置くだけです声明。ただし、配列を表示したい場合は、次のようにも記述する必要があります:

print $myarray;

出力結果は「Array」となり、PHP は $myarray が配列であることを示します。これは、変数が配列であるかどうかわからない場合に役立ちますが、ここでは配列の内容を確認したいと考えています。

implode 関数を使用して配列を文字列に変換できます。これには 2 つのパラメータが含まれており、1 つ目は配列変数名、2 つ目は配列内容の区切り文字です。変換が完了すると、配列の内容が区切り文字で接続されて文字列を形成します:

$implodedarray = implode ($myarray, ", "); 
print $implodedarray;

また、array_walk 関数を使用して配列を表示することもできます。この関数は、配列の各要素に対して同じ関数演算を実行します。例:

function printelement ($element) 
{ 
print ("$element< p>"); 
} 
array_walk($myarray, "printelement");

PHP を使用して MySQL にデータを送信する方法

次のコード部分は、非常に単純な HTML フォームです。

< html> 
< body> 
< form action=submitform.php3 method=GET> 
姓 : < input type=text name=first_name size=25 maxlength=25> 
名 : < input type=text name=last_name size=25 maxlength=25> 
< p> 
< input type=submit> 
< /form> 
< /body> 
< /html>

当你输入数据,并按下 submit 按钮后,这个表单将把数据发送到 submitform.php3 。再由这个 PHP 脚本来处理收到的数据,下面就是 submitform.php3 的代码: 

< html> 
< body> 
< ?php 
mysql_connect (localhost, username, passWord); 
mysql_select_db (dbname); 
mysql_query ("INSERT INTO tablename (first_name, last_name) 
VALUES (&#39;$first_name&#39;, &#39;$last_name&#39;) 
"); 
print ($first_name); 
print (" "); 
print ($last_name); 
print ("< p>"); 
print (" 感谢填写注册表 "); 
?> 
< /body> 
< /html>

在代码的第三行中的 "username" 和 "password" 分别代表你登陆 MySQL 数据库的账号和密码。在第五行中的 "dbname" 表示 MySQL 数据库的名称。在第十三行中的 "tablename" 是数据库中的一个数据表的名称。 

当你按下 submit 之后,可以看到你输入的名字被显示在一个新的页面中。再看一看浏览器的 URL 栏,它的内容应该是像这样的: 

… /submitform.php3?first_name=Fred&last_name=Flintstone

因为我们用到的是表单 GET 方法,因此数据是通过 URL 来传送到 submitform.php3 的。显然, GET 方法是有局限性的,当要传递的内容很多时,就不能用 GET 了,只能用 POST 方法。但不管用什么方法,当数据传送完成后, PHP 自动的为每一个表单中的字段建立一个和他们的名字(表单的 name 属性)相同的变量。 

PHP 变量都已用一个美元符号开头的,这样,在 submitform.php3 脚本处理的过程中,就会有 $first_name 和 $last_name 这两个变量了,变量的内容就是你输入的内容。 

我们来检查一下你输入的名字是否真的被输入到数据库中了。启动 MySQL, 在 mysql> 提示符下输入: 

mysql> select * from tablename;

你应该可以得到一个表,内容就是你刚才输入的了: 

+------------+------------+ 
| first_name | last_name | 
+------------+------------+ 
| 柳 | 如风 
+------------+------------+ 
1 rows in set (0.00 sec)

我们再来分析一下 submitform.php3 是如何工作的: 

脚本的开始两行是: 

mysql_connect (localhost, username, password); 
mysql_select_db (dbname);

这两个函数调用用来打开 MySQL 数据库,具体的参数的含义刚才已经说过了。 

下面的一行是执行一个 SQL 语句 : 

mysql_query ("INSERT INTO tablename (first_name, last_name) 
VALUES (&#39;$first_name&#39;, &#39;$last_name&#39;) 
");

mysql_query 函数就是用来对选定的数据库执行一个 SQL 查询。你可以在 mysql_query 函数中执行任何的 SQL 语句。被执行的 SQL 语句必须作为一个字符串用双引号括起来,在其中的变量要用单引号括起来。 

有一个要注意的事情: MySQL 的语句要用一个分号 (;) 结束,一行 PHP 代码同样也是这样,但是在 PHP 脚本中的 MySQL 语句是不能有分号的。也就是说,当你在 mysql> 的提示符下输入 MySQL 命令,你应该加上分号: 

INSERT INTO tablename (first_name, last_name) 
VALUES (&#39;$first_name&#39;, &#39;$last_name&#39;);

但是如果这个命令出现在 PHP 脚本中,就要去掉那个分号了。之所以这样做,是因为有的语句,如 SELECT 和 INSERT ,有没有分号都可以工作。但是还有一些语句,如 UPDATE ,加上分号就不行了。为了避免麻烦,记住这条规则就好了。 

PHP 如何从 MySQL 中提取数据 

现在我们建立另外一个 HTML 表单来执行这个任务: 

< html> 
< body> 
< form action=searchform.php3 method=GET> 
请输入您的查询内容 : 
< p> 
姓: < input type=text name=first_name size=25 maxlength=25> 
< p> 
名 : < input type=text name=last_name size=25 maxlength=25> 
< p> 
< input type=submit> 
< /form> 
< /body> 
< /html>

同样,还要有一个 php 脚本来处理这个表单,我们再建立一个 searchform.php3 文件: 

< html> 
< body> 
< ?php 
mysql_connect (localhost, username, password); 
mysql_select_db (dbname); 
if ($first_name == "") 
{$first_name = &#39;%&#39;;} 
if ($last_name == "") 
{$last_name = &#39;%&#39;;} 
$result = mysql_query ("SELECT * FROM tablename 
WHERE first_name LIKE &#39;$first_name%&#39; 
AND last_name LIKE &#39;$last_name%&#39; 
"); 
if ($row = mysql_fetch_array($result)) { 
do { 
print $row["first_name"]; 
print (" "); 
print $row["last_name"]; 
print ("< p>"); 
} while($row = mysql_fetch_array($result)); 
} else {print " 对不起,再我们的数据库中,没有找到符合的纪录。 ";} 
?> 
< /body> 
< /html>

当你在表单中输入了要检索的内容,再按下 SUBMIT 按钮后,就会进入一个新的页面,其中列出了所有匹配的搜索结果。下面再来看看这段脚本到底是怎样完成搜索任务的。 

前面的几条语句和上面讲到的一样,先是建立数据库连接,然后选定数据库和数据表,这些是每个数据库应用所必需的。然后有这样的几条语句: 

if ($first_name == "") 
{$first_name = &#39;%&#39;;} 
if ($last_name == "") 
{$last_name = &#39;%&#39;;}

这几行用来检查表单的各字段是否为空。要注意的是那两个等号,因为 PHP 的语法大多源于 C 语言,这儿等号的用法也同 C 一样:一个等号是赋值号,两个等号才代表逻辑等于。还应该注意的是:当 IF 后条件为真时,后面要执行的语句是放在“ { ”和“ } ”中的,并且其中的每一条语句后面都要加上分号表示语句结束。 

百分号 % 是 SQL 语言的通配符,理解了之一点后,就该知道这两行的意思了:如果“ FIRST_NAME ”字段为空,那么将列出所有的 FIRST_NAME 。后面的两句也是同样的意思。 

$result = mysql_query ("SELECT * FROM tablename 
WHERE first_name LIKE &#39;$first_name%&#39; 
AND last_name LIKE &#39;$last_name%&#39;" 
");

这一行完成了搜索的大部分工作。当 mysql_query 函数完成一个查询后,它返回一个整数标志。 

查询从所有的记录中选出那些 first_name 列和 $first_name 变量相同,并且 last_name 列和 $last_name 变量值也相同的记录,放到暂存的记录集中,并用返回的整数作为这个记录集的标志。 

if ($row = mysql_fetch_array($result)) { 
do { 
print $row["first_name"]; 
print (" "); 
print $row["last_name"]; 
print ("< p>"); 
}
 while($row = mysql_fetch_array($result)); 
} else {
print " 对不起,再我们的数据库中,没有找到符合的纪录。 ";
}

这是最后的一步,就是显示部分了。 mysql_fetch_array 函数先提取出查询结果的第一行的内容,在用 PRINT 语句显示出来。这个函数的参数就是 mysql_query 函数返回的整数标志。而 mysql_fetch_array 执行成功后,记录集指针会自动下移,这样当再一次执行 mysql_fetch_array 时,得到的就是下一行纪录的内容了。 

数组变量 $row 被 mysql_fetch_array 函数建立并用查询的结果字段来填充,数组的每一个分量对应于查询结果的每一个字段。 

如果有符合的纪录被找到,变量 $row 不会空,这时就会执行花括号中的语句: 

do { 
print $row["first_name"]; 
print (" "); 
print $row["last_name"]; 
print ("< p>"); 
} 
while($row = mysql_fetch_array($result));

这是一个 do … while 循环。与 while 循环不同的是,它是先执行一遍循环循环体,然后在检查循环条件是否满足。由于已经知道在纪录集不为空的情况下,肯定至少要把循环体执行一遍,所以应该用到的是 do … while 而不是 while 循环了。在花括号中的就是要执行的循环体: 

print $row["first_name"]; 
print (" "); 
print $row["last_name"]; 
print ("< p>");

 然后就是检查 while 条件是否满足。 Mysql_fetch_array 函数再次被调用,来得到当前纪录的内容。这个过程一直循环,当没有下一条纪录存在时, mysql_fetch_array 返回 false ,循环结束,纪录集也就被完全的遍历了一次。 

mysql_fetch_array($result) 返回的数组,不仅可以用字段名来调用,也可以像一般的数组那样,用下标来引用数组的各个分量。这样,上面的代码还可以写成这样: 

print $row[0]; 
print (" "); 
print $row[1]; 
print ("< p>");

我们还可以用 echo 函数来把这四条语句写的紧凑一些: 

echo $row[0], " ", $row[1], "< p>";

当没有任何匹配的纪录被找到时,在 $row 中就不会有任何内容,这时就会调用 if 语句的 else 子句了: 

else {
print " 对不起,再我们的数据库中,没有找到符合的纪录。 ";
}

检查查询是否正常工作 

你的那些 SELECT , DELETE 或者其它的查询是否能够正常工作呢?这是必须要搞清楚的,并且,千万不要轻易的就下结论。 

检查一个 INSERT 查询相对的简单一些: 

$result = mysql_query ("INSERT INTO tablename (first_name, last_name) 
VALUES (&#39;$first_name&#39;, &#39;$last_name&#39;) 
"); 
if(!$result) 
{ 
echo "< b>INSERT 查询失败 :< /b> ", mysql_error(); 
exit; 
}

但是这个检查的方法对于 SELECT 查询是行不通的,这时,应该这样作: 

$selectresult = mysql_query ("SELECT * FROM tablename 
WHERE first_name = &#39;$first_name&#39; 
AND last_name = &#39;$last_name&#39; 
"); 
if (mysql_num_rows($selectresult) == 1) 
{ 
print "SELECT 查询成功。 "; 
} 
elseif (mysql_num_rows($selectresult) == 0) 
{ 
print "SELECT 查询失败。 "; 
exit; 
}

而对于 DELETE 查询,就应该是这样了: 

$deleteresult = mysql_query ("DELETE FROM tablename 
WHERE first_name = &#39;$first_name&#39; 
AND last_name = &#39;$last_name&#39; 
"); 
if (mysql_affected_rows($deleteresult) == 1) 
{ 
print "DELETE 查询成功 "; 
} 
elseif (mysql_affected_rows($deleteresult) != 1) 
{ 
print "DELETE 查询失败 "; 
exit; 
}

以上就是PHP 和 MySQL 基础教程(一)的内容,更多相关内容请关注PHP中文网(www.php.cn)!

相关推荐: 

 关于mysql 基础知识的总结 

 PHP 和 MySQL 基础教程(二) 

 PHP 和 MySQL 基础教程(三) 

 PHP 和 MySQL 基础教程(四)

mysql手册教程:http://www.php.cn/course/37.html

mysql视频教程:http://www.php.cn/course/list/51.html

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPの目的:動的なWebサイトの構築PHPの目的:動的なWebサイトの構築Apr 15, 2025 am 12:18 AM

PHPは動的なWebサイトを構築するために使用され、そのコア関数には次のものが含まれます。1。データベースに接続することにより、動的コンテンツを生成し、リアルタイムでWebページを生成します。 2。ユーザーのインタラクションを処理し、提出をフォームし、入力を確認し、操作に応答します。 3.セッションとユーザー認証を管理して、パーソナライズされたエクスペリエンスを提供します。 4.パフォーマンスを最適化し、ベストプラクティスに従って、ウェブサイトの効率とセキュリティを改善します。

PHP:データベースとサーバー側のロジックの処理PHP:データベースとサーバー側のロジックの処理Apr 15, 2025 am 12:15 AM

PHPはMySQLIおよびPDO拡張機能を使用して、データベース操作とサーバー側のロジック処理で対話し、セッション管理などの関数を介してサーバー側のロジックを処理します。 1)MySQLIまたはPDOを使用してデータベースに接続し、SQLクエリを実行します。 2)セッション管理およびその他の機能を通じて、HTTPリクエストとユーザーステータスを処理します。 3)トランザクションを使用して、データベース操作の原子性を確保します。 4)SQLインジェクションを防ぎ、例外処理とデバッグの閉鎖接続を使用します。 5)インデックスとキャッシュを通じてパフォーマンスを最適化し、読みやすいコードを書き、エラー処理を実行します。

PHPでのSQL注入をどのように防止しますか? (準備された声明、PDO)PHPでのSQL注入をどのように防止しますか? (準備された声明、PDO)Apr 15, 2025 am 12:15 AM

PHPで前処理ステートメントとPDOを使用すると、SQL注入攻撃を効果的に防ぐことができます。 1)PDOを使用してデータベースに接続し、エラーモードを設定します。 2)準備方法を使用して前処理ステートメントを作成し、プレースホルダーを使用してデータを渡し、メソッドを実行します。 3)結果のクエリを処理し、コードのセキュリティとパフォーマンスを確保します。

PHPおよびPython:コードの例と比較PHPおよびPython:コードの例と比較Apr 15, 2025 am 12:07 AM

PHPとPythonには独自の利点と短所があり、選択はプロジェクトのニーズと個人的な好みに依存します。 1.PHPは、大規模なWebアプリケーションの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンスと機械学習の分野を支配しています。

アクション中のPHP:実際の例とアプリケーションアクション中のPHP:実際の例とアプリケーションApr 14, 2025 am 12:19 AM

PHPは、電子商取引、コンテンツ管理システム、API開発で広く使用されています。 1)eコマース:ショッピングカート機能と支払い処理に使用。 2)コンテンツ管理システム:動的コンテンツの生成とユーザー管理に使用されます。 3)API開発:RESTFUL API開発とAPIセキュリティに使用されます。パフォーマンスの最適化とベストプラクティスを通じて、PHPアプリケーションの効率と保守性が向上します。

PHP:インタラクティブなWebコンテンツを簡単に作成しますPHP:インタラクティブなWebコンテンツを簡単に作成しますApr 14, 2025 am 12:15 AM

PHPにより、インタラクティブなWebコンテンツを簡単に作成できます。 1)HTMLを埋め込んでコンテンツを動的に生成し、ユーザー入力またはデータベースデータに基づいてリアルタイムで表示します。 2)プロセスフォームの提出と動的出力を生成して、XSSを防ぐためにHTMLSPECIALCHARSを使用していることを確認します。 3)MySQLを使用してユーザー登録システムを作成し、Password_HashおよびPreprocessingステートメントを使用してセキュリティを強化します。これらの手法を習得すると、Web開発の効率が向上します。

PHPとPython:2つの一般的なプログラミング言語を比較しますPHPとPython:2つの一般的なプログラミング言語を比較しますApr 14, 2025 am 12:13 AM

PHPとPythonにはそれぞれ独自の利点があり、プロジェクトの要件に従って選択します。 1.PHPは、特にWebサイトの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンス、機械学習、人工知能に適しており、簡潔な構文を備えており、初心者に適しています。

PHPの永続的な関連性:それはまだ生きていますか?PHPの永続的な関連性:それはまだ生きていますか?Apr 14, 2025 am 12:12 AM

PHPは依然として動的であり、現代のプログラミングの分野で重要な位置を占めています。 1)PHPのシンプルさと強力なコミュニティサポートにより、Web開発で広く使用されています。 2)その柔軟性と安定性により、Webフォーム、データベース操作、ファイル処理の処理において顕著になります。 3)PHPは、初心者や経験豊富な開発者に適した、常に進化し、最適化しています。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、