很好用的PHP数据库类
时间:2024-05-11 09:52:10
<?
//很好用的PHP数据库类,三、四句代码搞定一个表的操作,无论这个表字段有多复杂。
//此类多次大量用在大型网站程序的开发上,效果特别的好。
//作者:快刀浪子++
define(\"_PHP_RECORD_\",\"exists\");
class TRecord
{
var $db;
var $rc;
var $name;
var $value;
var $num;
var $buffer; //查询结果调用方法$buffer[$i][\"fields\"];
var $seekstr; //保存查询条件用
function TRecord($host=\"localhost\",$user=\"root\",$passwd=\"\")
{global $HTTP_POST_VARS;
$this->num=0;
$this->host=$host;
$this->user=$user;
$this->passwd=$passwd;
if(($this->db=mysql_connect($host,$user,$passwd))==false)
exit(\"联结数据库出错!\");
while(list($this->name[$this->num],$this->value[$this->num])=each($HTTP_POST_VARS))
{$this->num++;
}
//////////////
for($i=0;$i<$this->num;$i++)
{$this->value[$i]=$this->SafeString($this->value[$i]);
}
//
}
function SafeString($message)
{$message=str_replace(\" \",\" \",$message);
$message=str_replace(\"<\",\"<\",$message);
$message=str_replace(\">\",\">\",$message);
//$message=str_replace(\"|\",\"|\",$message);
//$message=str_replace(\"\\"\",\""\",$message);
//$message=nl2br($message);
return $message;
}
//////
function reset()
{$this->num=0;
$this->name=array();
$this->value=array();
}
function add($name,$values)
{$this->name[$this->num]=$name;
$this->value[$this->num]=$values;
$this->num++;
}
function unadd($name)
{$j=0;
for($i=0;$i<$this->num;$i++)
{if($this->name[$i]!=$name)
{$aaa[$j]=$this->name[$i];
$bbb[$j]=$this->value[$i];
$j++;
}
}
$this->name=$aaa;
$this->value=$bbb;
$this->num=$j;
}
function InsertRecord($database,$table)
{mysql_select_db($database);
if($this->num==0)
exit(\"没有定义变量!\");
$field=implode(\",\",$this->name);
for($i=0;$i<$this->num;$i++)
{if(is_string($this->value[$i]))
$ls[$i]=\"\'\".$this->value[$i].\"\'\";
else
$ls[$i]=$this->value[$i];
$value=implode(\",\",$ls);
}
$sql=sprintf(\"insert into %s(%s) values(%s)\",$table,$field,$value);
if(mysql_query($sql,$this->db)==false)
{echo \"写数据到数据库时出错:\".$sql;
exit();
}
}
function SelectRecord($database,$table) //返回记录数,结果在缓冲区中
{mysql_select_db($database);
if($this->num==0)
$sql=sprintf(\"select * from %s\",$table);
else
{
for($i=0;$i<$this->num;$i++)
{if(is_string($this->value[$i]))
$ls[$i]=\"\'\".$this->value[$i].\"\'\";
else
$ls[$i]=$this->value[$i];
$str[$i]=sprintf(\"%s=%s\",$this->name[$i],$ls[$i]);
}
$string=implode(\" and \",$str);
$this->seekstr=$string;
$sql=sprintf(\"select * from %s where %s\",$table,$string);
}
if(($rc=mysql_query($sql,$this->db))==false)
{echo \"查询数据库时出错:\".$sql;
exit();
}
$i=0;
while($this->buffer[$i]=mysql_fetch_array($rc))
{
$i++;
}
mysql_free_result($rc);
return $i;
}
function UpdateRecord($database,$table,$limitstr)
{mysql_select_db($database);
if($this->num==0)
exit(\"没有定义变量!\");
for($i=0;$i<$this->num;$i++)
{if(is_string($this->value[$i]))
$ls[$i]=\"\'\".$this->value[$i].\"\'\";
else
$ls[$i]=$this->value[$i];
$upstr[$i]=$this->name[$i].\"=\".$ls[$i];
}
$str=implode(\",\",$upstr);
$sql=sprintf(\"update %s set %s where %s\",$table,$str,$limitstr);
if(mysql_query($sql,$this->db)==false)
{echo \"修改数据时出错:\".$sql;
exit();
}
}
function addtip($database,$table,$fileds,$limitstr=\"\")
{//必须为整型字段
mysql_select_db($database);
if($limitstr!=\"\")
$sql=sprintf(\"update %s set %s=%s+1 where %s\",$table,$fileds,$fileds,$limitstr);
else
$sql=sprintf(\"update %s set %s=%s+1\",$table,$fileds,$fileds);
if(mysql_query($sql,$this->db)==false)
{echo \"修改数据时出错:\".$sql;
exit();
}
}
function unaddtip($database,$table,$fileds,$limitstr=\"\")
{
mysql_select_db($database);
if($limitstr!=\"\")
$sql=sprintf(\"update %s set %s=%s-1 where %s\",$table,$fileds,$fileds,$limitstr);
else
$sql=sprintf(\"update %s set %s=%s-1\",$table,$fileds,$fileds);
if(mysql_query($sql,$this->db)==false)
{echo \"修改数据时出错:\".$sql;
exit();
}
}
function isempty($var,$china)
{if(trim($var)==\"\")
{
$reason=\"没有录入“\".$china.\"”!\";
exit($reason);
}
}
function GetResult()
{return $this->buffer;
}
function close()
{
mysql_close($this->db);
}
}
?>
标签:PHP,数据库类
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Hadoop分布式集群的搭建的方法步骤
2022-06-08 06:02:42
CentOS 7 安装 MySQL 5.6遇到的各种问题小结
2024-01-20 23:51:39
![](https://img.aspxhome.com/file/2023/4/70014_0s.png)
使用pandas读取文件的实现
2022-10-20 14:00:42
基于Python函数的作用域规则和闭包(详解)
2023-09-03 09:00:28
pandas DataFrame 警告(SettingWithCopyWarning)的解决
2023-08-20 07:45:31
学习Python中一些实用的库
2022-11-02 13:55:56
![](https://img.aspxhome.com/file/2023/3/117343_0s.png)
利用rest framework搭建Django API过程解析
2021-08-09 21:33:46
![](https://img.aspxhome.com/file/2023/0/109600_0s.png)
PHP获取网页标题的3种实现方法代码实例
2024-05-03 15:51:06
MySQL基础教程第一篇 mysql5.7.18安装和连接教程
2024-01-15 18:55:19
![](https://img.aspxhome.com/file/2023/5/112325_0s.jpg)
基于Python的身份证号码自动生成程序
2022-11-29 02:00:33
![](https://img.aspxhome.com/file/2023/3/96993_0s.jpg)
教你怎么用Python实现自动生日祝福
2022-04-08 01:03:25
![](https://img.aspxhome.com/file/2023/7/127697_0s.png)
Eclipse+Java+Swing+Mysql实现电影购票系统(详细代码)
2024-01-16 08:09:21
![](https://img.aspxhome.com/file/2023/5/94375_0s.png)
Python使用Matplotlib绘制甘特图的实践
2021-04-06 03:16:56
![](https://img.aspxhome.com/file/2023/4/121754_0s.png)
银行账号输入格式化, 支持部分浏缆器
2007-09-26 18:27:00
Python实现的NN神经网络算法完整示例
2023-10-06 04:30:41
![](https://img.aspxhome.com/file/2023/2/63542_0s.png)
ASP实现网站智能分词搜索
2007-10-18 13:50:00
python日期与时间戳的各种转换示例
2021-05-23 07:47:33
virtualenv 指定 python 解释器的版本方法
2023-08-20 16:49:51
Oracle临时表空间删除和重建实现过程
2023-07-18 09:26:04
浅谈PyQt5中异步刷新UI和Python多线程总结
2023-08-22 01:37:18