0

0

php编写的mysql 操作类 php5的

PHP中文网

PHP中文网

发布时间:2016-05-25 17:10:39

|

1072人浏览过

|

来源于php中文网

原创

php编写的mysql 操作类 php5的 

 "4.1") {   
if($dbcharset) {  
mysql_query("SET character_set_connection={$dbcharset}, character_set_results=$dbcharset, character_set_client=binary", self::$link);  
}  
if(self::version() > "5.0.1") {  
mysql_query("SET sql_mode=''", self::$link);  
}  
}  
if($dbname) {  
mysql_select_db($dbname, self::$link);  
}  
}  
/**  
* 选择数据库  
*  
* @param string $dbname  
* @return   
*/  
static function select_db($dbname) {  
return mysql_select_db($dbname, self::$link);  
}  
/**  
* 取出结果集中一条记录  
*  
* @param object $query  
* @param int $result_type  
* @return array  
*/  
static function fetch_array($query, $result_type = MYSQL_ASSOC) {  //默认只取关联数组 不取数字数组.
return mysql_fetch_array($query, $result_type);  
}  
 
/**  
* 查询SQL  
*  
* @param string $sql  
* @param string $type  
* @return object  
*/  
static function query($sql, $type = "") {  
 $func = $type == "UNBUFFERED" && @function_exists("mysql_unbuffered_query") ?  
"mysql_unbuffered_query" : "mysql_query";  
if(!($query = $func($sql, self::$link)) && $type != "SILENT") {  
self::halt("MySQL Query Error", $sql);  
}  
self::$querynum++;  
return $query;  
}  
/**  
* 取影响条数  
*  
* @return int  
*/  
static function affected_rows() {  
return mysql_affected_rows(self::$link);  
}  
/**  
* 返回错误信息  
*  
* @return array  
*/  
static function error() {  
return ((self::$link) ? mysql_error(self::$link) : mysql_error());  
}  
/**  
* 返回错误代码  
*  
* @return int  
*/  
static function errno() {  
return intval((self::$link) ? mysql_errno(self::$link) : mysql_errno());  
}  
/**  
* 返回查询结果  
*  
* @param object $query  
* @param string $row  
* @return mixed  
*/  
static function result($query, $row,$flname=0) {  
$query = @mysql_result($query, $row,$flname);  
return $query;  
}  
/**  
* 结果条数  
*  
* @param object $query  
* @return int  
*/  
static function num_rows($query) {  
$query = mysql_num_rows($query);  
return $query;  
}  
/**  
* 取字段总数  
*  
* @param object $query  
* @return int  
*/  
static function num_fields($query) {  
return mysql_num_fields($query);  
}  
/**  
* 释放结果集  
*  
* @param object $query  
* @return bool  
*/  
static function free_result($query) {  
return @mysql_free_result($query);  
}  
/**  
* 返回自增ID  
*  
* @return int  
*/  
static function insert_id() {  
return ($id = mysql_insert_id(self::$link)) >= 0 ? $id : self::$result(self::$query("SELECT last_insert_id()"), 0);  
}  
/**  
* 从结果集中取得一行作为枚举数组  
*  
* @param object $query  
* @return array  
*/  
static function fetch_row($query) {  
$query = mysql_fetch_row($query);  
return $query;  
}  
/**  
* 从结果集中取得列信息并作为对象返回  
*  
* @param object $query  
* @return object  
*/  
static function fetch_fields($query) {  
return mysql_fetch_field($query);  
}  

static function select_affectedt_rows($rs){
	 return mysql_affected_rows($rs,self::$link);
	
}
/**  
* 返回mysql版本  
*  
* @return string  
*/  
static function version() {  
return mysql_get_server_info(self::$link);  
}  
/**  
* 关闭连接  
*  
* @return bool  
*/  
static function close() {  
return mysql_close(self::$link);  
}  
/**  
* 输出错误信息  
*  
* @param string $message  
* @param string $sql  
*/  
static function halt($message = "", $sql = "") {
	 @header("Content-type: text/html; charset=utf-8");
	 
	if (DEBUG==1){
		$debug = debug_backtrace();
		echo $message . "\r\n
SQL--> " . $sql."\r\n
ERROR_MESSAGE-->".self::error(). "\r\n
--------------debug--------------\r\n
"; self::echoarray($debug); echo "\r\n
-------------debug end----------------"; }else{ echo 'SQL Error'; } @self::rollback(); exit; } /////////////////////////////以下是扩展的sql方法.////// /* 把数组按照 key value value 的对应关系插入数据表table中 table 要插入的数据表 要注意 这些扩展方法是没自己给表有加前缀的. */ static function insert($table,$array){ $temp="";$temp2=''; foreach($array as $key=>$value){ if(self::$is_type_tight){ if(is_string($value)){ $temp .="$key,";$temp2 .="'$value',"; }elseif(is_int($value||is_null($value)||is_float($value))){ $value+=0; $temp .="$key,";$temp2 .="'$value',"; } }else{ $temp .="$key,";$temp2 .="'$value',"; } } $temp = substr($temp,0,strlen($temp)-1); $temp2 = substr($temp2,0,strlen($temp2)-1); $sql = "INSERT INTO $table ($temp) VALUE($temp2)"; return self::query($sql); } static function del($table,$where){ $sql = "DELETE FROM {$table} where {$where}"; return self::query($sql); } static function update($table,$array,$where){ foreach ($array as $key=>$value){ $temp .= "$key='$value',"; } $temp = substr($temp,0,strlen($temp)-1); $sql = "update {$table} set ($temp) where {$where} "; return self::query($sql); } /*进行数据库查询select 参数不定 参数说明:所有参数必须是string 第一个参数必须是表名; 从第二个参数起, 如果是写上 "where:XXX" 则认为是where条件; 如果写上 "xxx" 则认为是键值 如果写上 "by:XXX" 则认为是排序 如果写上 "limit:xxx,xxx" 则认为是分页 #参数不正确则返回false; 成功查询返回查询后的数组; */ static function select(){ $numargs = func_num_args();//获取参数个数; $where = "";$key="";$limit="";$by=""; if($numargs==0){return false;} //echo $numargs; if($numargs>=2){ $arg_list = func_get_args(); $table = $arg_list[0]; unset($arg_list[0]); // print_r($arg_list); foreach($arg_list as $k=>$value){ if(preg_match("#^(where:)\w#",$value)){ $temp = explode(":",$value); $where = "WHERE {$temp[1]} " ; }elseif(preg_match("#^by:\w#",$value)){ $temp = explode(":",$value); $by = "order by {$temp[1]}" ; }elseif(preg_match("#^limit:\w#",$value)){ $temp = explode(":",$value); $limit = "limit {$temp[1]}"; }else{ $key .= "$value,"; } } if($key==""){ $key = "*"; }else{ $key =substr($key,0,strlen($key)-1); } $sql_base="SELECT $key FROM $table"; } if(!empty($where)){ $sql_base .= " $where"; } if(!empty($by)){ $sql_base .= " $by"; } if(!empty($limit)){ $sql_base .= " $limit"; } //echo $sql_base; //echo $by ; $rs = self::query($sql_base); $re=array(); if(self::num_rows($rs)>=1){ while($info = self::fetch_array($rs)){ $re[]=$info; } } self::free_result($rs); return $re; } /*回滚事务*/ static function rollback(){ self::query('rollback'); } /*开始事务*/ static function begin(){ self::query('SET AUTOCOMMIT =0'); //停用自动提交; self::query('BEGIN') ;//开始一个事务; } /*提交事务*/ static function commit(){ self::query('commit'); } static function echoarray($array){ foreach($array as $k=>$v ){ if(is_array($v)){ if(is_array($v)){ echo "
--------------------------------
"; self::echoarray($v); } }else{ if($k==='line') echo "$k -> " .$v." "; else echo "$k -> " .$v." "; } } } static function get_server_info(){ return mysql_get_server_info(); } } ?>

 以上就是php编写的mysql 操作类 php5的 的内容,更多相关内容请关注PHP中文网(www.php.cn)!

LANUX蓝脑商务网站系统
LANUX蓝脑商务网站系统

LANUX V1.0 蓝脑商务网站系统 适用于网店、公司宣传自己的品牌和产品。 系统在代码、页面方面设计简约,浏览和后台管理操作效率高。 此版本带可见即可得的html编辑器, 方便直观添加和编辑要发布的内容。 安装: 1.解压后,更换logo、分类名称、幻灯片的图片及名称和链接、联系我们等等页面。 2.将dbconfig.php里面的数据库配置更改为你的mysql数据库配置 3.将整个文件夹上传至

下载

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
植物大战僵尸版本入口地址汇总
植物大战僵尸版本入口地址汇总

本专题整合了植物大战僵尸版本入口地址汇总,前往文章中寻找想要的答案。

3

2026.02.03

c语言中/相关合集
c语言中/相关合集

本专题整合了c语言中/的用法、含义解释。阅读专题下面的文章了解更多详细内容。

1

2026.02.03

漫蛙漫画网页版入口与正版在线阅读 漫蛙MANWA官网访问专题
漫蛙漫画网页版入口与正版在线阅读 漫蛙MANWA官网访问专题

本专题围绕漫蛙漫画(Manwa / Manwa2)官网网页版入口进行整理,涵盖漫蛙漫画官方主页访问方式、网页版在线阅读入口、台版正版漫画浏览说明及基础使用指引,帮助用户快速进入漫蛙漫画官网,稳定在线阅读正版漫画内容,避免误入非官方页面。

0

2026.02.03

Yandex官网入口与俄罗斯搜索引擎访问指南 Yandex中文登录与网页版入口
Yandex官网入口与俄罗斯搜索引擎访问指南 Yandex中文登录与网页版入口

本专题汇总了俄罗斯知名搜索引擎 Yandex 的官网入口、免登录访问地址、中文登录方法与网页版使用指南,帮助用户稳定访问 Yandex 官网,并提供一站式入口汇总。无论是登录入口还是在线搜索,用户都能快速获取最新稳定的访问链接与使用指南。

4

2026.02.03

Java 设计模式与重构实践
Java 设计模式与重构实践

本专题专注讲解 Java 中常用的设计模式,包括单例模式、工厂模式、观察者模式、策略模式等,并结合代码重构实践,帮助学习者掌握 如何运用设计模式优化代码结构,提高代码的可读性、可维护性和扩展性。通过具体示例,展示设计模式如何解决实际开发中的复杂问题。

2

2026.02.03

C# 并发与异步编程
C# 并发与异步编程

本专题系统讲解 C# 异步编程与并发控制,重点介绍 async 和 await 关键字、Task 类、线程池管理、并发数据结构、死锁与线程安全问题。通过多个实战项目,帮助学习者掌握 如何在 C# 中编写高效的异步代码,提升应用的并发性能与响应速度。

1

2026.02.03

Python 强化学习与深度Q网络(DQN)
Python 强化学习与深度Q网络(DQN)

本专题深入讲解 Python 在强化学习(Reinforcement Learning)中的应用,重点介绍 深度Q网络(DQN) 及其实现方法,涵盖 Q-learning 算法、深度学习与神经网络的结合、环境模拟与奖励机制设计、探索与利用的平衡等。通过构建一个简单的游戏AI,帮助学习者掌握 如何使用 Python 训练智能体在动态环境中作出决策。

2

2026.02.03

python end=
python end=

本专题整合了python中end=的相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.02.03

python运算符优先级
python运算符优先级

本专题整合了python运算符优先级排序、用法相关内容,阅读专题下面的文章了解更多详细内容。

2

2026.02.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 10.9万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号