AJAX MySQL 数据库与PHP的实例演示

数据库 MySQL
本文主要向大家描述的是PHP 与 AJAX MySQL 数据库实例演示,以及在其实际操作中我们大家需要注意的事项的描述。

此文章主要向大家介绍的是PHP 与 AJAX MySQL 数据库实例演示,我们大家都知道 AJAX 的主要功能可用来和数据库进行交互式通信。那么PHP的相关功能又是如何呢?以下的文章就有对其的详细介绍。

AJAX 数据库实例

在下面的 AJAX MySQL 数据库实例中,我们将演示网页如何使用 AJAX 技术从 MySQL 数据库中读取信息。

 

在下拉列表中选择一个名字 (测试说明:该实例功能未实现)

Select a User: Peter Griffin Lois Griffin Joseph Swanson Glenn Quagmire

 

 

在此列出用户信息。

 

此列由四个元素组成:

 

MySQL 数据库

简单的 HTML 表单

 

JavaScript

 

PHP 页面

 

数据库

 

将在本例中使用的数据库看起来类似这样:

 

id FirstName LastName Age Hometown Job

1 Peter Griffin 41 Quahog Brewery

 

2 Lois Griffin 40 Newport Piano Teacher

 

3 Joseph Swanson 39 Quahog Police Officer

 

4 Glenn Quagmire 41 Quahog Pilot

 

HTML 表单

上面的例子包含了一个简单的 HTML 表单,以及指向 JavaScript 的链接:

  1. <html><head><script src="selectuser.js"></script></head><body><form> Select a User:

     

    <select name="users" onchange="showUser(this.value)"><option value="1">Peter 

     

    Griffin
    </option><option value="2">Lois Griffin</option><option value="3">Glenn 

     

    Quagmire
    </option><option value="4">Joseph Swanson</option></select></form><p><div 

     

    id="txtHint"><b>User info will be listed here.</b></div></p></body></html> 

例子解释 - HTML 表单

正如您看到的,它仅仅是一个简单的 HTML 表单,其中带有名为 "users" 的下拉列表,这个列表包含了姓名,以及与数据库的 "id" 对应的选项值。

 

表单下面的段落包含了名为 "txtHint" 的 div。这个 div 用作从 web 服务器检索到的信息的占位符。

当用户选择数据时,执行名为 "showUser()" 的函数。该函数的执行由 "onchange" 事件触发。

换句话说:每当用户改变下拉列表中的值,就会调用 showUser() 函数。

JavaScript

这是存储在 "selectuser.js" 文件中的 JavaScript 代码:

  1. var xmlHttpfunction showUser(str){ xmlHttp=GetXmlHttpObject()if (xmlHttp==null) 

     

    { alert ("Browser does not support HTTP Request") return }var 
    urlurl="getuser.

     

    php"url=url+"?
    q="+strurl=url+"&sid="+Math.random()xmlHttp.onreadystatechange=stateChanged xmlHttp.

     

    open("GET",url,true)xmlHttp.send(null)}function stateChanged() 

     

    { if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete") 

     

    { document.getElementById("txtHint").innerHTML=xmlHttp.responseText } }function 

     

    GetXmlHttpObject(){var xmlHttp=null;try { // Firefox, Opera 8.0+, 

     

    Safari xmlHttp=new XMLHttpRequest(); }catch (e) { //Internet Explorer try 

     

    { xmlHttp=new ActiveXObject("
    Msxml2.XMLHTTP"); } catch (e) { xmlHttp=new ActiveXObject("Microsoft.XMLHTTP"); } }return xmlHttp;} 

例子解释:

stateChanged() 和 GetXmlHttpObject 函数与 PHP AJAX MySQL 数据库请求 那一节中的相同,您可以参阅其中的相关解释。

 

showUser() 函数

假如下拉列表中的项目被选择,函数执行:

 

调用 GetXmlHttpObject 函数来创建 XMLHTTP 对象

定义发送到服务器的 URL(文件名)

 

向 URL 添加带有下拉列表内容的参数 (q)

 

添加一个随机数,以防服务器使用缓存的文件

 

当触发事件时调用 stateChanged

 

通过给定的 URL 打开 XMLHTTP 对象

 

向服务器发送 HTTP 请求

 

PHP 页面

 

由 JavaScript 调用的服务器页面,是名为 "getuser.php" 的简单 PHP 文件。

 

该页面用 PHP 编写,并使用 MySQL 数据库。

其中的代码执行针对数据库的 SQL 查询,并以 HTML 表格返回结果:

  1. <?php$q=$_GET["q"];$con = mysql_connect('localhost', 'peter', 'abc123');

     

    if (!$con) { die('Could not connect: ' . mysql_error()); }mysql_select_db("ajax_demo", $con);

     

    $
    sql="SELECT * FROM user WHERE id = '".$q."'";$result = mysql_query($sql);

     

    echo "
    <table border='1'><tr><th>Firstname</th><th>Lastname</th><th>Age</th><th>

     

    Hometown</th><th>Job</th></tr>";while($row = mysql_fetch_array($result)) 

     

    { echo "
    <tr>"; echo "<td>" . $row['FirstName'] . "</td>"; echo "<td>" . 

     

    $row['LastName'] . "
    </td>"; echo "<td>" . $row['Age'] . "</td>"; echo "<td>" . 

     

    $row['Hometown'] . "
    </td>"; echo "<td>" . $row['Job'] . "</td>"; echo "</tr>"; }echo "</table>";mysql_close($con); 

?>例子解释:

当查询从 JavaScript 被发送到这个 PHP 页面,会发生:

PHP 打开到达 MySQL 服务器的连接

找到拥有指定姓名的 "user"

 

创建表格,插入数据,然后将其发送到 "txtHint" 占位符

上述的相关内容就是对PHP 和 AJAX MySQL 数据库实例 AJAX 可用来与数据库进行交互式通信的描述,希望会给你带来一些帮助在此方面。

【编辑推荐】

  1. Ubuntu MySQL设置同步服务器
  2. Ubuntu mysql可以把data防止到内存盘中
  3. CentOS系统操作mysql的常用命令
  4. CentOS系统找回mysql登录密码
  5. 使用mysqldump备份数据库的具体步骤
责任编辑:佚名 来源: cnblogs
相关推荐

2010-06-02 11:34:23

MySQL 数据库导入

2010-05-12 18:41:34

MySQL数据库

2010-06-01 14:42:55

连接MySQL数据库

2010-06-09 17:36:45

MySQL数据库同步

2010-06-12 17:55:23

MySQL数据库同步

2010-05-28 14:51:47

MySQL数据库

2010-06-01 16:50:29

MySQL存储过程

2010-07-16 14:17:18

SQL Server

2010-06-04 09:33:28

连接MySQL数据库

2010-08-10 11:35:42

DB2数据库

2010-06-01 10:47:21

连接MySQL数据库

2010-06-12 09:53:19

2010-06-07 16:22:55

MySQL数据库

2011-06-21 15:11:04

QT 数据库

2010-05-27 10:10:00

连接MySQL数据库

2009-09-03 11:42:32

2010-05-26 14:24:24

MySQL数据库

2010-05-28 10:34:39

连接MySQL数据库

2010-05-28 13:21:48

MySQL数据库

2011-07-05 10:16:16

Qt 数据库 SQLite
点赞
收藏

51CTO技术栈公众号