程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php 之 沒有mysql支持時的替代方案

php 之 沒有mysql支持時的替代方案

編輯:關於PHP編程

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

通過以上可以方便的解決常用的網頁運用,比如聊天室,BBS論壇,書簽之類
如果那位大蝦有更好的解決方法,請賜教!謝謝!
我的主頁:feiyschool.51.net
QQ:23072155
email:[email protected]

【本文版權歸作者feiy與奧索網共同擁有,如需轉載,請注明作者及出處】    


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved