Ajax PHP 邊學(xué)邊練 之三 數(shù)據(jù)庫
更新時間:2009年11月26日 01:29:05 作者:
在上一篇備忘日歷實例中,實現(xiàn)了當(dāng)鼠標(biāo)放在某個日期上時,如果當(dāng)天有備忘信息則會顯示出來,但是這些信息是為了測試方便事先寫在數(shù)組中的數(shù)據(jù),不能體現(xiàn)其實時性。
本篇將繼續(xù)通過該實例講解與數(shù)據(jù)庫的交互方式。實例中用到的是MySQL,也可以根據(jù)自己的需要替換為其他數(shù)據(jù)庫,其連接方式可以參考PHP相關(guān)手冊。
在下面源程序包中dbconnector.php 提供了與MySQL的連接函數(shù)。
<?php
//定義數(shù)據(jù)連接變量
define ("MYSQLHOST", "localhost");
define ("MYSQLUSER", "root");
define ("MYSQLPASS", "root");
define ("MYSQLDB", "test");
function opendatabase(){
//連接數(shù)據(jù)庫所在服務(wù)器
$db = mysql_connect (MYSQLHOST,MYSQLUSER,MYSQLPASS);
try {
if (!$db){
//若無法連接則提示錯誤
$exceptionstring = "Error connection to database: <br />";
$exceptionstring .= mysql_errno().": ".mysql_error();
throw new exception ($exceptionstring);
}
else{
//連接數(shù)據(jù)庫(test)
mysql_select_db (MYSQLDB,$db);
}
return $db;
}catch (exception $e){
echo $e->getmessage();
die();
}
}
?>
當(dāng)鼠標(biāo)放到某個日期上時會調(diào)用functions.js中的checkfortasks函數(shù)。同時checkfortasks會加載taskchecker.php程序,它會到MySQL中查詢該日期下所有的備忘錄信息,并將結(jié)果返回到頁面中。
<?php
//調(diào)用數(shù)據(jù)庫連接程序
require_once ("dbconnector.php");
//連接數(shù)據(jù)庫
$db = opendatabase();
//在MySQL查詢備忘錄
$querystr = "SELECT description FROM task WHERE thedate='" . addslashes ($_GET['thedate']) . "'";
//執(zhí)行SQL
if ($datequery = mysql_query ($querystr)){
//判斷查詢是否有值
if (mysql_num_rows ($datequery) > 0){
?>
<div style="width: 150px; background: #FFBC37; border-style: solid; border-color: #000000; border-width: 1px;">
<div style="padding: 10px;">
<?php
//顯示備忘錄信息
while ($datedata = mysql_fetch_array ($datequery)){
if (!get_magic_quotes_gpc()){
echo stripslashes ($datedata['description']);
}
else{
echo $datedata['description'];
}
}
?>
</div>
</div>
<?php
}
}
else{
//數(shù)據(jù)庫查詢錯誤
echo mysql_error();
}
//關(guān)閉數(shù)據(jù)庫
mysql_close ($db);
?>
對于Ajax的使用和上一篇的原理是一樣的:1. 通過事件調(diào)用Ajax函數(shù);2. 通過函數(shù)請求其他PHP程序,PHP程序中可以對數(shù)據(jù)庫之類的數(shù)據(jù)源進行讀、寫、改操作;3. 將處理結(jié)果加載到事件激發(fā)頁面。在下圖中鼠標(biāo)放到26號時,Ajax會在MySQL中查詢到“Football Match”事件并加載到當(dāng)前頁面。
源代碼下載
在下面源程序包中dbconnector.php 提供了與MySQL的連接函數(shù)。
復(fù)制代碼 代碼如下:
<?php
//定義數(shù)據(jù)連接變量
define ("MYSQLHOST", "localhost");
define ("MYSQLUSER", "root");
define ("MYSQLPASS", "root");
define ("MYSQLDB", "test");
function opendatabase(){
//連接數(shù)據(jù)庫所在服務(wù)器
$db = mysql_connect (MYSQLHOST,MYSQLUSER,MYSQLPASS);
try {
if (!$db){
//若無法連接則提示錯誤
$exceptionstring = "Error connection to database: <br />";
$exceptionstring .= mysql_errno().": ".mysql_error();
throw new exception ($exceptionstring);
}
else{
//連接數(shù)據(jù)庫(test)
mysql_select_db (MYSQLDB,$db);
}
return $db;
}catch (exception $e){
echo $e->getmessage();
die();
}
}
?>
當(dāng)鼠標(biāo)放到某個日期上時會調(diào)用functions.js中的checkfortasks函數(shù)。同時checkfortasks會加載taskchecker.php程序,它會到MySQL中查詢該日期下所有的備忘錄信息,并將結(jié)果返回到頁面中。
復(fù)制代碼 代碼如下:
<?php
//調(diào)用數(shù)據(jù)庫連接程序
require_once ("dbconnector.php");
//連接數(shù)據(jù)庫
$db = opendatabase();
//在MySQL查詢備忘錄
$querystr = "SELECT description FROM task WHERE thedate='" . addslashes ($_GET['thedate']) . "'";
//執(zhí)行SQL
if ($datequery = mysql_query ($querystr)){
//判斷查詢是否有值
if (mysql_num_rows ($datequery) > 0){
?>
<div style="width: 150px; background: #FFBC37; border-style: solid; border-color: #000000; border-width: 1px;">
<div style="padding: 10px;">
<?php
//顯示備忘錄信息
while ($datedata = mysql_fetch_array ($datequery)){
if (!get_magic_quotes_gpc()){
echo stripslashes ($datedata['description']);
}
else{
echo $datedata['description'];
}
}
?>
</div>
</div>
<?php
}
}
else{
//數(shù)據(jù)庫查詢錯誤
echo mysql_error();
}
//關(guān)閉數(shù)據(jù)庫
mysql_close ($db);
?>
對于Ajax的使用和上一篇的原理是一樣的:1. 通過事件調(diào)用Ajax函數(shù);2. 通過函數(shù)請求其他PHP程序,PHP程序中可以對數(shù)據(jù)庫之類的數(shù)據(jù)源進行讀、寫、改操作;3. 將處理結(jié)果加載到事件激發(fā)頁面。在下圖中鼠標(biāo)放到26號時,Ajax會在MySQL中查詢到“Football Match”事件并加載到當(dāng)前頁面。

源代碼下載
您可能感興趣的文章:
- ajax php 實現(xiàn)寫入數(shù)據(jù)庫
- php從數(shù)據(jù)庫中獲取數(shù)據(jù)用ajax傳送到前臺的方法
- php+ajax 實現(xiàn)輸入讀取數(shù)據(jù)庫顯示匹配信息
- PHP jQuery+Ajax結(jié)合寫批量刪除功能
- php+ajax實現(xiàn)圖片文件上傳功能實例
- php的ajax簡單實例
- php+ajax實現(xiàn)無刷新動態(tài)加載數(shù)據(jù)技術(shù)
- php采用ajax數(shù)據(jù)提交post與post常見方法總結(jié)
- ThinkPHP中使用ajax接收json數(shù)據(jù)的方法
- php+ajax+jquery實現(xiàn)點擊加載更多內(nèi)容
- PHP+jQuery+Ajax實現(xiàn)用戶登錄與退出
- php + ajax 實現(xiàn)的寫入數(shù)據(jù)庫操作簡單示例
相關(guān)文章
PHP 雜談《重構(gòu)-改善既有代碼的設(shè)計》之四 簡化條件表達式
條件邏輯有可能十分復(fù)雜,因此本章提供一些重構(gòu)的手法,專門用來簡化它們2012-04-04PHP常用特殊運算符號和函數(shù)總結(jié)(php新手入門必看)
新手經(jīng)常會有一些PHP特殊符號的問題,這里把常用的特殊符號整理一下。如果你全部都會用,那就當(dāng)是溫故知新吧2013-02-02PHP提示Cannot modify header information - headers already sent
這篇文章主要介紹了PHP提示Cannot modify header information - headers already sent by解決方法,是在PHP程序開發(fā)中非常典型的錯誤情況,非常具有實用價值,需要的朋友可以參考下2014-09-09php iconv() : Detected an illegal character in input string
PHP傳給JS字符串用ecsape轉(zhuǎn)換加到url里,又用PHP接收,再用網(wǎng)上找的unscape函數(shù)轉(zhuǎn)換一下,這樣得到的字符串是UTF-8的,但我需要的是GB2312,于是用iconv轉(zhuǎn)換2010-12-12