Ajax PHP 邊學(xué)邊練 之三 數(shù)據(jù)庫
更新時(shí)間:2009年11月26日 01:29:05 作者:
在上一篇備忘日歷實(shí)例中,實(shí)現(xiàn)了當(dāng)鼠標(biāo)放在某個(gè)日期上時(shí),如果當(dāng)天有備忘信息則會(huì)顯示出來,但是這些信息是為了測(cè)試方便事先寫在數(shù)組中的數(shù)據(jù),不能體現(xiàn)其實(shí)時(shí)性。
本篇將繼續(xù)通過該實(shí)例講解與數(shù)據(jù)庫的交互方式。實(shí)例中用到的是MySQL,也可以根據(jù)自己的需要替換為其他數(shù)據(jù)庫,其連接方式可以參考PHP相關(guān)手冊(cè)。
在下面源程序包中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){
//若無法連接則提示錯(cuò)誤
$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)放到某個(gè)日期上時(shí)會(huì)調(diào)用functions.js中的checkfortasks函數(shù)。同時(shí)checkfortasks會(huì)加載taskchecker.php程序,它會(huì)到MySQL中查詢?cè)撊掌谙滤械膫渫浶畔?,并將結(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ù)庫查詢錯(cuò)誤
echo mysql_error();
}
//關(guān)閉數(shù)據(jù)庫
mysql_close ($db);
?>
對(duì)于Ajax的使用和上一篇的原理是一樣的:1. 通過事件調(diào)用Ajax函數(shù);2. 通過函數(shù)請(qǐng)求其他PHP程序,PHP程序中可以對(duì)數(shù)據(jù)庫之類的數(shù)據(jù)源進(jìn)行讀、寫、改操作;3. 將處理結(jié)果加載到事件激發(fā)頁面。在下圖中鼠標(biāo)放到26號(hào)時(shí),Ajax會(huì)在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){
//若無法連接則提示錯(cuò)誤
$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)放到某個(gè)日期上時(shí)會(huì)調(diào)用functions.js中的checkfortasks函數(shù)。同時(shí)checkfortasks會(huì)加載taskchecker.php程序,它會(huì)到MySQL中查詢?cè)撊掌谙滤械膫渫浶畔?,并將結(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ù)庫查詢錯(cuò)誤
echo mysql_error();
}
//關(guān)閉數(shù)據(jù)庫
mysql_close ($db);
?>
對(duì)于Ajax的使用和上一篇的原理是一樣的:1. 通過事件調(diào)用Ajax函數(shù);2. 通過函數(shù)請(qǐng)求其他PHP程序,PHP程序中可以對(duì)數(shù)據(jù)庫之類的數(shù)據(jù)源進(jìn)行讀、寫、改操作;3. 將處理結(jié)果加載到事件激發(fā)頁面。在下圖中鼠標(biāo)放到26號(hào)時(shí),Ajax會(huì)在MySQL中查詢到“Football Match”事件并加載到當(dāng)前頁面。
源代碼下載
您可能感興趣的文章:
- ajax php 實(shí)現(xiàn)寫入數(shù)據(jù)庫
- php從數(shù)據(jù)庫中獲取數(shù)據(jù)用ajax傳送到前臺(tái)的方法
- php+ajax 實(shí)現(xiàn)輸入讀取數(shù)據(jù)庫顯示匹配信息
- PHP jQuery+Ajax結(jié)合寫批量刪除功能
- php+ajax實(shí)現(xiàn)圖片文件上傳功能實(shí)例
- php的ajax簡單實(shí)例
- php+ajax實(shí)現(xiàn)無刷新動(dòng)態(tài)加載數(shù)據(jù)技術(shù)
- php采用ajax數(shù)據(jù)提交post與post常見方法總結(jié)
- ThinkPHP中使用ajax接收json數(shù)據(jù)的方法
- php+ajax+jquery實(shí)現(xiàn)點(diǎn)擊加載更多內(nèi)容
- PHP+jQuery+Ajax實(shí)現(xiàn)用戶登錄與退出
- php + ajax 實(shí)現(xiàn)的寫入數(shù)據(jù)庫操作簡單示例
相關(guān)文章
PHP 雜談《重構(gòu)-改善既有代碼的設(shè)計(jì)》之四 簡化條件表達(dá)式
條件邏輯有可能十分復(fù)雜,因此本章提供一些重構(gòu)的手法,專門用來簡化它們2012-04-04
PHP常用特殊運(yùn)算符號(hào)和函數(shù)總結(jié)(php新手入門必看)
新手經(jīng)常會(huì)有一些PHP特殊符號(hào)的問題,這里把常用的特殊符號(hào)整理一下。如果你全部都會(huì)用,那就當(dāng)是溫故知新吧2013-02-02
PHP提示Cannot modify header information - headers already sent
這篇文章主要介紹了PHP提示Cannot modify header information - headers already sent by解決方法,是在PHP程序開發(fā)中非常典型的錯(cuò)誤情況,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-09-09
PHP觀察者模式原理與簡單實(shí)現(xiàn)方法示例
這篇文章主要介紹了PHP觀察者模式原理與簡單實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了php觀察者模式的概念、原理、實(shí)現(xiàn)方法及相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-08-08
數(shù)據(jù)庫中排序的對(duì)比及使用條件詳解
PHP與MySQL數(shù)據(jù)庫中排序的對(duì)比及使用條件是本文我們主要要介紹的內(nèi)容,通常來說,執(zhí)行效率需要考慮CPU、內(nèi)存和硬盤等的負(fù)載情況2012-02-02
PHP實(shí)現(xiàn)的限制IP投票程序IP來源分析
這篇文章主要介紹了PHP實(shí)現(xiàn)的限制IP投票程序,針對(duì)投票程序中客戶端IP的判斷方法進(jìn)行了深入分析,并給出了偽造IP的方法供大家參考了解,需要的朋友可以參考下2016-05-05
php 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

