首頁  >  文章  >  後端開發  >  php沒有mysql支援時的替代方案

php沒有mysql支援時的替代方案

WBOY
WBOY原創
2016-08-08 09:33:56979瀏覽

一般個人免費主頁空間都不會提供MySQL支持,就是提供也很苛刻,所以尋找也個良好的替代方案很重要哦!
php的檔案處理功能很強大,所以可以用檔案的存取來代替!
(要知道沒有資料庫的時候,什麼都是用檔案組織的哦!呵呵!),其中個資料項用特殊符號分割,我採用的是“||”,方便透過explode()函數讀取單一記錄!
其實這裡資料庫的想法還是可以用到的!象資料庫的索引!
所以必須先做個索引檔! (這樣說也不正確)
就以留言本來說吧:
主要文件有:
index.database
其結構如下:
留言人姓名||留言人性別||留言時間||留言內容存放位置||feiyn(這項是方便讀取時的被‘n’幹惱的!
每個儲存一行可以方便的透過PHP的fgets()函數讀取,或是file()函數讀取每行到陣列
為了防止多人同是對資料的寫入衝突,故還需要加鎖(也用檔案實作)
以下是寫入程式碼
//必須傳入以下參量:
//留言人姓名 $name
//留言人性別 $sex
//留言時間  $time
//留言內容存放位置 $savePosite
$indexFile="index.database";
$indexFileLock=$indexFile."Lock";
$message=$name."||".$sex."||".$time."||".$savePosite."||feiy||";//這就是要寫入的記錄
while(file_exists($indexFileLock)) $temp++; //偵測是否已加鎖
fclose(fopen($indexFileLock,"w"));      //如沒有則進入並加鎖避免同是存取衝突
$fp=fopen($indexFile,"a");
fputs($message,strlen($message));
fclose($fp);
unlink($indexFileLock);//解鎖
?>
讀取代碼
$indexFile="index.database";
$indexFileLock=$indexFile."Lock";
while(file_exists($indexFileLock)) $temp++; //偵測是否已加鎖
fclose(fopen($indexFileLock,"w"));      //如沒有則進入並加鎖避免同是存取衝突
$ary=file($indexFile);
unlink($indexfileLock);//解鎖
for($i=0;$i $tempAry=explode("||",$ary[$i]);
echo("name:".$tempAry[0]);
echo("sex:".$tempAry[1]);
echo("sex:".$tempAry[2]);
echo("savePosite:",$tempAry[3]);//可以從該位址讀取留言內容
}
?>

透過以上可以方便的解決常用的網頁運用,例如聊天室,BBS論壇,書籤之類
如果那位大蝦有更好的解決方法,請賜教!謝謝!





以上就介紹了php沒有mysql支援時的替代方案,包括了方面的內容,希望對PHP教程有興趣的朋友有幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn