国产午夜成人免费看片无遮挡_日本免费xxxx色视频_免费人成网上在线观看_黄网址在线永久免费观看

當前位置:雨林木風下載站 > 技術開發教程 > 詳細頁面

一組文件數據庫函數

一組文件數據庫函數

更新時間:2022-05-06 文章作者:未知 信息來源:網絡 閱讀次數:

<?
/**
* 文件數據庫函數
* 約定:
* 數據庫名為同名目錄
* 數據表名后綴為 tab
* 索引文件后綴為 ind
* 管理文件名為 數據庫同名目錄/manage.ini
* 備注型字段以獨立文件存在,表中保留文件名
* 字段以定長方式或csv方式保存,由管理文件指定
* 每行一條記錄
* 索引文件以二進制方式包存鍵值(定長)和偏移量(長整型)
*

** 函數列表(前面有:+ 為已實現,- 為部分實現,其余為尚未實現)
套用 MySQL 函數集 取名 FILE_DB

* file_affected_rows: 得到 FILE_DB 最后操作影響的列數目。
*-file_close: 關閉 FILE_DB 服務器連接。
* file_connect: 打開 FILE_DB 服務器連接。
*+file_create_db: 建立一個 FILE_DB 新數據庫。
* file_data_seek: 移動內部返回指針。
* file_db_query: 送查詢字符串 (query) 到 FILE_DB 數據庫。
* file_drop_db: 移除數據庫。
* file_errno: 返回錯誤信息代碼。
* file_error: 返回錯誤信息。
*+file_fetch_array: 返回數組資料。
* file_fetch_field: 取得字段信息。
* file_fetch_lengths: 返回單列各欄資料最大長度。
* file_fetch_object: 返回類資料。
*+file_fetch_row: 返回單列的各字段。
*+file_field_name: 返回指定字段的名稱。
* file_field_seek: 配置指針到返回值的某字段。
* file_field_table: 獲得目前字段的資料表 (table) 名稱。
* file_field_type: 獲得目前字段的類型。
* file_field_flags: 獲得目前字段的標志。
* file_field_len: 獲得目前字段的長度。
* file_free_result: 釋放返回占用內存。
* file_insert_id: 返回最后一次使用 INSERT 指令的 ID。
* file_list_fields: 列出指定資料表的字段 (field)。
* file_list_dbs: 列出 FILE_DB 服務器可用的數據庫 (database)。
* file_list_tables: 列出指定數據庫的資料表 (table)。
*+file_num_fields: 取得返回字段的數目。
*+file_num_rows: 取得返回列的數目。
* file_pconnect: 打開 FILE_DB 服務器持續連接。
*-file_query: 送出一個 query 字符串。
* file_result: 取得查詢 (query) 的結果。
* file_select_db: 選擇一個數據庫。
* file_tablename: 取得資料表名稱。
*/

/**
*
*
$cmp_key;

/** 連結至 FILE_DB 資料庫
* @param 數據庫名
*/
function &file_connect($dbname) {
$filename = $dbname."/manage.ini";
if(!file_exists($filename))
die("數據庫:$dbnamee不存在");
$fp = fopen($filename,"r");
$s = fgets($fp,filesize($filename)+1);
fclose($fp);
$db = unserialize($s);
return $db;
}

/** 關閉 FILE_DB 連結
*
*/
function file_close(&$connection_id) {
unset($connection_id);
}

/** 建立 FILE_DB 數據庫
* @param 數據庫名
*/
function file_create_db($dbname) {
if(! @mkdir($dbname,0700))
$err = "目錄已存在";
$filename = $dbname."/manage.ini";
$ar[path] = "$dbname/";
$s = serialize($ar);
$fp = fopen($filename,"w");
fputs($fp,$s);
fclose($fp);
}

/** 執行 SQL 指令
*
*/
function file_query($query,&$connection_id,$_line = __LINE__) {
// 解析 $query
$query = eregi_replace("[ ]+"," ",$query);
$ar = split(" ",trim(str_replace(""," ",$query)));
$query = eregi_replace("\r?\n","",$query);
$ch = each($ar);
switch(strtoupper($ch[1])) {
case "CREATE":
if(! eregi("create table (.+) [(] *(.+)[)] *$",$query,$pp))
die("SQL表達式錯,$_line");
$table = $pp[1];
if(empty($connection_id[$table])) {
// 解析字段表達式
$ar = split(",",$pp[2]);
while(list($key,$value) = each($ar)) {
$str = split(" ",trim($value));
eregi("([a-z0-9]+) ([a-z]+) ?([(]([0-9]+)[)])?(.+)?",$value,$pp);
$field[name] = $pp[1];
$field[type] = $pp[2];
$field[len] = $pp[4];
$field[style] = trim($pp[5]);
$sss[] = $field;
}
$connection_id[$table] = array(
"fields" => $sss,
"filename" => $table.".tab",
"type" => "CSV"
);
}
$fp = fopen($connection_id[path]."manage.ini","w");
fputs($fp,serialize($connection_id));
fclose($fp);
break;
case "SELECT":
if(! eregi("select (.+) from ([^ ]+) *(.+)*$",$query,$pp))
die("SQL表達式錯,$_line");

// 解析SQL語句的控制部分
$exte = $pp[3];
if(! eregi("where ",$exte))
$exte = "where true ".$exte;
if(! eregi("order ",$exte))
$exte .= "order by 0";
if(! eregi("group ",$exte))
$exte = eregi_replace("order ","group by _ order ",$exte);

eregi("where (.+) *group by (.+) order by (.+)",$exte,$regs);
$filter = trim($regs[1]);
$group = trim($regs[2]);
$order = trim($regs[3]);
if($group == "_") $group = "";
if($order == "0") $order = "";
// 讀取數據文件
if(empty($connection_id[$pp[2]]))
die("表".$pp[2]."不存在");
$table = $connection_id[$pp[2]];
if(!file_exists($connection_id[path].$table[filename])) {
// 數據表尚未建立
return false;
}else {
// 獲取表定義字段名
for($i=0;$i<count($table[fields]);$i++)
$defaultfield[] = $table[fields][$i][name];
$defaultfield = array_flip($defaultfield);

// 解析篩選表達式
if($filter != "true") {
$filter = eregi_replace(" and "," && ",$filter);
$filter = eregi_replace(" or "," || ",$filter);
$filter = eregi_replace("=","==",$filter);
$filter = eregi_replace("==>","=>",$filter);
$filter = eregi_replace("<==","<=",$filter);
$filter = eregi_replace("===","==",$filter);
while (ereg ('([a-z][a-z0-9_]*)', $filter, $regs)) {
$found = $regs[1];
$filter = eregi_replace("$found","[". $defaultfield][$found]."]", $filter);
}
$filter = eregi_replace("\[","\$tmp][",$filter);
$filter = "\$key=($filter);";
}else
$filter ="";

 // 裝入數據
$fp = fopen($connection_id][path].$table[filename],"r");
$key = true;
while($tmp = fgetcsv($fp,4096,"`")) {
if(!empty($filter)) eval($filter);
if($key)
$temp[] = $tmp;
}
fclose($fp);
}
// 解析輸出字段
$f = split(",",$pp[1]);
$expr = "";
while(list($key,$value) = each($f)) {
if(eregi("(.+)[(](.+)[)]( as (.+))?",$value,$pp)) {
// 有函數
switch(strtoupper($pp[1])) {
case "COUNT":
if(empty($pp[4]))
$n = "cnt";
else
$n = $pp[4];
$expr .= "\$rs[$n]=1;";
$sumname[] = $n;
break;
}
}else if(eregi("(.+) as (.+)",$value,$pp)) {
// 有重命名
$n = $defaultfield[$pp[1]];
if(!isset($n)) die("字段名 $n 非法");
$expr .= "\$rs[$pp[2]]=\$temp[\$i][$n];";
}else if($value == "*") {
for($i=0;$i<count($table[fields]);$i++) {
$value = $table[fields][$i][name];
$expr .= "\$rs[$value]=\$temp[\$i][$i];";
}
}else {
$n = $defaultfield[$value];
if(!isset($n)) die("SQL error");
$expr .= "\$rs[$value]=\$temp[\$i][$n];";
}
}

// 取得輸出字段列表
$i=0;
eval($expr);
$outfield = array_keys($rs);

// 解析分組
if($group) {
$groups = split(",",$group);
for($i=0;$i<count($groups);$i++)
if(eregi("[0-9]+",$groups[$i])) {
$n = $groups[$i]>0?$groups[$i]-1:0;
$groups[$i] = $outfield[$n];
}
}

// 過錄數據
for($i=0;$i<count($temp);$i++) {
eval($expr);
if(!$group)
$result[] = $rs;
else {
$n = $rs[$groups[0]];
if($sumname) {
for($ii=0;$ii<count($sumname);$ii++)
$sumdata[$sumname][$ii]] = $result[$n][$sumname][$ii]];
$result[$n] = $rs;
for($ii=0;$ii<count($sumname);$ii++)
$result[$n][$sumname][$ii]] += $sumdata[$sumname][$ii]];
}else
$result[$n] = $rs;
}
}
unset($temp);

// 解析排序
if($order) {
global $cmp_key;
$orders = split(",",$order);
for($i=count($orders)-1;$i>=0;$i--) {
eregi("([0-9]+)?([a-z_][a-z0-9_]*)? *(desc)?",$orders[$i],$regs);
if(!empty($regs[1])) {
$n = $regs[1]-1;
if($n<0) $n = 0;
$cmp_key = $outfield[$n];
}else
$cmp_key = $regs[2];
if(empty($regs[3]))
usort($result, cmp_asc);
else
usort($result, cmp_desc);
}
}
return $result;
break;
case "INSERT":
if(! eregi("insert into table (.+) [(](.+)[)] *values? *[(](.+)[)]",$query,$pp))
die("SQL表達式錯,$_line");
if(empty($connection_id[$pp[1]]))
die("表".$pp[1]."不存在");
$table = $connection_id[$pp[1]];
// 解析目標字段名
$f = split(",",$pp[2]);
// 檢查字段是否合法
for($i=0;$i<count($f);$i++)
if(!array_scan($table[fields],$f[$i],"name"))
die("字段名非法 ".$f[$i]);
// 根據表字段表構造數據數組
for($i=0;$i<count($table[fields]);$i++)
$data[$table][fields][$i][name]] = "";
// 解析數據
eval("\$d=array($pp[3]);");
// 填表
for($i=0;$i<count($f);$i++) {
$data[$f[$i]] = $d[$i];
}
$fp = fopen($connection_id[path].$table[filename],"a");
fputs($fp,join("`",$data)."\n");
fclose($fp);
break;
case "UPDATE":
break;
default:
die("錯誤的SQL指令,在".$_line."行");
}


}

/** file_fetch_row: 返回單列的各字段
*
*/
function file_fetch_row(&$result) {
$ar = each($result);
if(! $ar) return false;
while(list($k,$ch) = each($ar[1]))
$br[] = $ch;
return $br;
}

/** file_fetch_array: 返回數組資料
*
*/
function file_fetch_array(&$result) {
$ar = each($result);
if(! $ar) return false;
while(list($k,$ch) = each($ar[1])) {
$br[] = $ch;
$br[$k] = $ch;
}
return $br;
}

/** file_field_name: 返回指定字段的名稱
*
*/
function file_field_name(&$result,$n=0) {
$outfield = array_keys($result[0]);
return $outfield[$n];
}

/** file_num_rows: 取得返回列的數目
*
*/
function file_num_rows(&$result) {
return count($result);
}

/** file_num_fields: 取得返回字段的數目
*
*/
function file_num_fields(&$result) {
return count($result[0]);
}


/** 工作函數集
*/

/** 在數組中檢索
* @param $ar 數組
* @param $val 待檢索的值
* @param $key 鍵
*/
function array_scan($ar,$val,$key=0) {
for($i=0;$i<count($ar);$i++)
if($ar[$i][$key] == $val)
return true;
return false;
}

/** 排序用工作函數(降序 由usort()調用)
*/
function cmp_desc($a,$b) {
global $cmp_key;
if ($a[$cmp_key] == $b[$cmp_key]) return 0;
return ($a[$cmp_key] > $b[$cmp_key]) ? -1 : 1;
}

/** 排序用工作函數(升序 由usort()調用)
*/
function cmp_asc($a,$b) {
global $cmp_key;
if ($a[$cmp_key] == $b[$cmp_key]) return 0;
return ($a[$cmp_key] > $b[$cmp_key]) ? 1 : -1;
}




// 應用實例

file_create_db("test");
$conn = file_connect("test");

$s = "create table board (
sn int primary key auto_increment,
name varchar(15) not null,
email varchar(30),
ip varchar(15),
time datetime,
content tinyblob not null)";
file_query($s,$conn);
//file_query("insert into table board (sn,name,ip) value (15,'w,r,r,oi','$REMOTE_ADDR')",$conn);

//$rs = file_query("select * from board",$conn);
$rs = file_query("select * from board where true group by 2 order by 2 desc",$conn);
//$rs = file_query("select count(*) as js,time as hj,ip as pi,name,sn from board group by name order by sn desc",$conn);
//$rs = file_query("select sn,name,email,io from board where true group by 1 order by 2 desc",$conn);
file_close($conn);

echo "<table border = 1>";
echo "<tr>";
for($i=0;$i<file_num_fields($rs);$i++)
echo "<th>".file_field_name($rs,$i)."</th>";
echo "</tr>";
for($j=0;$j<file_num_rows($rs);$j++) {
echo "<tr>";
$d = file_fetch_row($rs);
for($i=0;$i<file_num_fields($rs);$i++)
echo "<td>".$d[$i]."</td>";
echo "</tr>";
}
echo "";
?>

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

国产午夜成人免费看片无遮挡_日本免费xxxx色视频_免费人成网上在线观看_黄网址在线永久免费观看

  • <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        欧美大黄免费观看| 欧美精选在线播放| 91免费看视频| 国产午夜精品久久久久久久 | 麻豆91精品91久久久的内涵| 91天堂素人约啪| 国产欧美精品区一区二区三区| 国产麻豆9l精品三级站| 国产精品一区在线观看乱码| 91麻豆精品国产| 性做久久久久久免费观看欧美| 色哟哟在线观看一区二区三区| 中文乱码免费一区二区| 国产最新精品免费| wwwwxxxxx欧美| 国产一区二区不卡在线| 国产网红主播福利一区二区| 国产精品一区二区在线观看网站 | 亚洲福利视频三区| 91免费在线视频观看| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 国产盗摄视频一区二区三区| 亚洲精品一区二区三区影院 | 中文字幕一区二区在线播放| 成熟亚洲日本毛茸茸凸凹| 国产片一区二区三区| 国产69精品久久久久777| 日本一区二区视频在线观看| 国产99久久久国产精品潘金| 亚洲视频在线一区| 91在线无精精品入口| 亚洲电影在线免费观看| 欧美夫妻性生活| 精品一区二区三区蜜桃| 日本一区二区视频在线| 欧美日韩久久不卡| 日韩高清中文字幕一区| 国产日韩欧美精品电影三级在线 | 亚洲欧美日韩系列| 欧美久久一区二区| 国产精品亚洲一区二区三区在线 | 国产精品传媒入口麻豆| 色综合激情久久| 日韩精品91亚洲二区在线观看| 欧美精品一区二区三区在线| 91在线精品一区二区| 日韩国产一二三区| 亚洲国产成人午夜在线一区| 国产在线乱码一区二区三区| 欧美精品一区二区三区在线播放| 国产美女精品一区二区三区| 日韩欧美一级片| 成人高清伦理免费影院在线观看| 亚洲风情在线资源站| 欧美激情中文字幕一区二区| 欧美二区三区的天堂| 成人精品视频一区二区三区| 免费黄网站欧美| 亚洲欧美偷拍三级| 欧美人牲a欧美精品| 丁香婷婷综合色啪| 日本欧美一区二区| 亚洲一区精品在线| 中文乱码免费一区二区| 26uuu精品一区二区| 欧美无人高清视频在线观看| 国产91综合网| 青青草视频一区| 亚洲欧美电影一区二区| 26uuu欧美| 91精品国产欧美一区二区18 | 国产一区不卡精品| 亚洲综合小说图片| 国产精品色在线观看| 欧美变态tickling挠脚心| 91福利在线看| 色综合视频在线观看| www.激情成人| 国产在线视频不卡二| 国产一区视频在线看| 久久精品国产99国产精品| 日韩中文字幕91| 亚洲午夜一二三区视频| 依依成人精品视频| 亚洲人成在线播放网站岛国| 亚洲精品伦理在线| 亚洲人被黑人高潮完整版| 亚洲欧美二区三区| 亚洲欧美电影一区二区| 亚洲一区二区欧美激情| 一区二区三区不卡在线观看| 亚洲午夜在线视频| 午夜精品福利一区二区三区蜜桃| 亚洲成人7777| 亚洲午夜影视影院在线观看| 婷婷成人激情在线网| 亚洲成人激情av| 日本三级亚洲精品| 精东粉嫩av免费一区二区三区| 国产成人av福利| 男人的j进女人的j一区| 亚洲一区在线免费观看| 亚洲人快播电影网| 午夜电影网一区| 精品一区二区在线视频| 成人午夜视频在线观看| 一本在线高清不卡dvd| 91精品国模一区二区三区| 日韩精品一区二区三区中文不卡| 久久久另类综合| 中文字幕欧美日韩一区| 亚洲国产一区在线观看| 青娱乐精品视频| 成人激情开心网| 欧美日韩一区二区三区在线| 91精品国产综合久久精品| 欧美精品一区二区三区高清aⅴ | 欧美日韩高清一区二区三区| 日韩一区二区三区精品视频| 国产亲近乱来精品视频| 亚洲欧美视频在线观看| 蜜桃视频一区二区| 97久久精品人人做人人爽| 日韩欧美不卡一区| 中文字幕亚洲一区二区va在线| 免费久久99精品国产| 99精品热视频| www国产精品av| 亚洲国产日韩一区二区| 国产精品一级片在线观看| 欧美揉bbbbb揉bbbbb| 欧美一级高清片在线观看| 精品国产一区久久| 国产精品水嫩水嫩| 一区二区三区国产豹纹内裤在线 | 国产在线精品免费av| 不卡欧美aaaaa| 2020国产精品自拍| 亚洲午夜久久久久中文字幕久| 国产精品一品二品| 日韩一区二区三区视频| 亚洲国产成人91porn| 高清免费成人av| 精品福利二区三区| 日韩国产在线观看一区| 在线亚洲免费视频| 国产精品黄色在线观看| 捆绑调教一区二区三区| 欧美日韩一区二区三区四区| 最新国产の精品合集bt伙计| 国产成人av电影| 久久麻豆一区二区| 久久99国产精品成人| 欧美精品九九99久久| 亚洲一区二区在线视频| 丰满放荡岳乱妇91ww| 国产欧美精品日韩区二区麻豆天美| 老司机精品视频导航| 日韩女优毛片在线| 日本网站在线观看一区二区三区| 欧美日韩午夜精品| 久久精品视频网| 亚洲综合色丁香婷婷六月图片| 奇米影视7777精品一区二区| 色婷婷综合久久久| 国产免费成人在线视频| 秋霞午夜av一区二区三区| 91精品国产麻豆| 亚洲国产sm捆绑调教视频| 精品视频999| 午夜精品久久久久久久久久久| 欧美喷潮久久久xxxxx| 喷白浆一区二区| 精品福利一区二区三区| 懂色av中文字幕一区二区三区| 国产清纯在线一区二区www| 国产成人午夜电影网| 国产精品久久777777| 91看片淫黄大片一级| 亚洲电影你懂得| 欧美一级高清大全免费观看| 成人夜色视频网站在线观看| 亚洲视频资源在线| 在线成人免费观看| 狠狠色综合日日| 国产精品国产成人国产三级| 在线观看一区不卡| 蜜臀精品一区二区三区在线观看| 久久日韩粉嫩一区二区三区 | 亚洲尤物在线视频观看| 欧美一级黄色录像| 国产成人综合网| 亚洲综合丝袜美腿| 精品久久久久久久久久久久包黑料| 国产精品一区二区在线看| 一区二区三区欧美视频| 日韩视频一区二区在线观看| 成人免费av网站| 日韩精品亚洲一区二区三区免费| 国产欧美在线观看一区|