您现在的位置是:首页 > cms教程 > phpcms教程phpcms教程
phpcms源码分析数据库类实现方法
从蓉2025-06-12phpcms教程已有人查阅
导读这个讲phpcms 的数据库类和phpcms 的文本缓存的实现.看了看都是很简单的东西.大家看着我注释慢慢看吧.慢慢理解,较好能装了PHPCMS
这个讲phpcms 的数据库类和phpcms 的文本缓存的实现.看了看都是很简单的东西.大家看着我注释慢慢看吧.慢慢理解,较好能装了PHPCMS 在来看.因为这样可以看下它的数据库结构信息.可以帮助理解.
不明白的继续问吧.
首先是数据库类,phpcms 的数据库 分mysql 和mssql 版本.MSSQL 版本的我就不说了.
他们主要的sql 语句不同点就在于我们分页常用到的 limit语句.所以.在 mssql 数据库类驱动里.他做了个挺好的封装.
让MYSQL 和MSSQL在SQL语句方面的差异性就很小了.可以说PHPCMS你可以随便转换数据库只要在代码中换下数据库类驱动就行.
不明白的继续问吧.
首先是数据库类,phpcms 的数据库 分mysql 和mssql 版本.MSSQL 版本的我就不说了.
他们主要的sql 语句不同点就在于我们分页常用到的 limit语句.所以.在 mssql 数据库类驱动里.他做了个挺好的封装.
让MYSQL 和MSSQL在SQL语句方面的差异性就很小了.可以说PHPCMS你可以随便转换数据库只要在代码中换下数据库类驱动就行.
<?php
/*
mysql数据库类。写得比较简单。也没什么好说的。大家自己看下理解下。
然后就可以跳过了。
*/
/*
这个东西是不是很熟呀。对了。在上一章已经讲过了。也已经在上一章的common.inc.php 启动文件里面定义了IN_PHPCMS
所以在以下的PHP文件里都检测下是否是人为”跳墙“进来的。是就中断
*/
defined('IN_PHPCMS') or exit('Access Denied');
/*
* Mysql 数据库类,支持Cache功能
*/
class db_mysql
{
/*
* MySQL 连接标识
* @var resource
*/
var $connid;
/*
* 整型变量用来计算被执行的sql语句数量
* @var int
*/
var $querynum = 0;
/*
* 数据库连接,返回数据库连接标识符
* @param string 数据库服务器主机
* @param string 数据库服务器帐号
* @param string 数据库服务器密码
* @param string 数据库名
* @param bool 是否保持持续连接,1为持续连接,0为非持续连接
* @return link_identifier
*/
function connect($dbhost, $dbuser, $dbpw, $dbname, $pconnect = 0)
{
global $CONFIG;
/*
mysql_pconnect()为常连接。它和mysql_connect 的区别是 前者在多进程的WEB服务器上效率比较好。
但也有瑕疵就是在有关事务和数据表锁方面。详情请查看自己的手册。
*/
$func = $pconnect == 1 ? 'mysql_pconnect' : 'mysql_connect';
if(!$this->connid = @$func($dbhost, $dbuser, $dbpw))
{
$this->halt('Can not connect to MySQL server');
}
// 当mysql版本为4.1以上时,启用数据库字符集设置
if($this->version() > '4.1' && $CONFIG['dbcharset'])
{
mysql_query("SET NAMES '".$CONFIG['dbcharset']."'" , $this->connid);
}
// 当mysql版本为5.0以上时,设置sql mode,mysql5数据库带了字符集模式。设置下就好
if($this->version() > '5.0')
{
mysql_query("SET sql_mode=''" , $this->connid);
}
if($dbname)
{
// if($email=!@mysql_select_db($dbname)!@mysql_select_db($dbname($email) , $this->connid))
{
$this->halt('Cannot use database '.$dbname);
}
}
return $this->connid;
}
/*
* 选择数据库
* @param string 数据库名
*/
function select_db($dbname)
{
return mysql_select_db($dbname , $this->connid);
}
/*
* 执行sql语句
* @param string sql语句
* @param string 默认为空,可选值为 CACHE UNBUFFERED
* @param int Cache以 秒为单位 的生命周期
* @return resource
*/
function query($sql , $type = '' , $expires = 3600, $dbname = '')
{
/*
mysql_unbuffered_query 效率更好。节省内存 看手册
*/
$func = $type == 'UNBUFFERED' ? 'mysql_unbuffered_query' : 'mysql_query';
if(!($query = $func($sql , $this->connid)) && $type != 'SILENT')
{
$this->halt('MySQL Query Error', $sql);
}
$this->querynum++;
return $query;
}
/*
* 执行sql语句,只得到一条记录
* @param string sql语句
* @param string 默认为空,可选值为 CACHE UNBUFFERED
* @param int Cache以秒为单位的生命周期
* @return array
*/
function get_one($sql, $type = '', $expires = 3600, $dbname = '')
{
$query = $this->query($sql, $type, $expires, $dbname);
$rs = $this->fetch_array($query);
$this->free_result($query);
return $rs ;
}
/*
* 从结果集中取得一行作为关联数组
* @param resource 数据库查询结果资源
* @param string 定义返回类型
* @return array
*/
function fetch_array($query, $result_type = MYSQL_ASSOC)
{
return mysql_fetch_array($query, $result_type);
}
/*
* 取得前一次 MySQL 操作所影响的记录行数
* @return int
*/
function affected_rows()
{
return mysql_affected_rows($this->connid);
}
/*
* 取得结果集中行的数目
* @return int
*/
function num_rows($query)
{
return mysql_num_rows($query);
}
/*
* 返回结果集中字段的数目
* @return int
*/
function num_fields($query)
{
return mysql_num_fields($query);
}
/*
* @return array
*/
function result($query, $row)
{
return @mysql_result($query, $row);
}
function free_result($query)
{
return mysql_free_result($query);
}
/*
* 取得上一步 INSERT 操作产生的 ID
* @return int
*/
function insert_id()
{
return mysql_insert_id($this->connid);
}
/*
* @return array
*/
function fetch_row($query)
{
return mysql_fetch_row($query);
}
/*
* @return string
*/
function version()
{
return mysql_get_server_info($this->connid);
}
function close()
{
return mysql_close($this->connid);
}
/*
* @return string
*/
function error()
{
return @mysql_error($this->connid);
}
/*
* @return int
*/
function errno()
{
/*
mysql_errno()函数也挺好使的哦。自己试下
*/
return intval(@mysql_errno($this->connid)) ;
}
/*
* 显示mysql错误信息
*/
function halt($message = '', $sql = '')
{
exit("MySQL Query:$sql <br>
MySQL Error:".$this->error()." <br>
MySQL Errno:".$this->errno()." <br>
Message:$message");
}
}
?>
本文标签:
很赞哦! ()
相关教程
图文教程
PHPCMSv9安全防范设置方法
一、目录权限设置很重要:可以有效防范黑客上传木马文件.如果通过 chmod 644 * -R 的话,php文件就没有权限访问了。如果通过chmod 755 * -R 的话,php文件的权限就高了。
隐藏PHPCMS管理入口的方法
phpcms默认的后台地址为http://你的网址/admin,如果不修改的话,站点的安全系数会大大降低。phpcms2008以前的版本可以直接将admin文件夹改名
PHPCMS上传报错413的解决方法
PHPCMS上传错误413,其原因Nginx默认限制大上传文件就是1M,所以上传文件超过1M就会报413错误,解决方法:找到“nginx.conf”配置下的“client_max_body_size”
PHPCMS和帝国CMS的评论管理功能哪个好用
phpcms和帝国cms在评论管理功能上的异同点如下:1. phpcms提供灵活的评论审核和分级回复功能,通过数据库操作实现。2. 帝国cms注重简洁和易用性,支持评论的审核、删除和排序
相关源码
-
(PC+WAP)激光水幕音乐喷泉设备工程网站源码下载本模板基于PbootCMS系统开发,为喷泉设备工程类企业设计,特别适合展示音乐喷泉、激光水幕等水景艺术项目。采用响应式技术,确保各类工程案例在不同设备上都能呈现视觉效果。查看源码 -
(自适应响应式)黑色LED显示屏户外广告屏网站源码下载这是一款基于PbootCMS内核开发的响应式网站模板,专门为LED显示屏及户外广告行业打造。模板适配各类显示设备,帮助企业快速搭建专业官网,展示产品与服务优势,有效提升品牌形象。查看源码 -
帝国cms7.5大型游戏资讯门户网站源码免费下载本模板基于帝国CMS7.5内核开发,为大型游戏资讯门户网站设计。模板自带响应式手机版,适配多种终端设备。内容架构针对游戏行业特点优化,支持游戏资讯、评测、攻略等内容类型的发布与管理。查看源码 -
(自适应多语言)WordPress开源主题MirageV资讯个人博客源码MirageV资讯类个人博客主题源码/WordPress主题/全开源MirageV 是一款开源的 WordPress 主题,支持自适应、暗黑模式、多语言等功能,查看源码 -
(自适应响应式)英文外贸电子产品手机配件网站pbootcms模板专业级外贸网站模板基于PbootCMS内核开发,为电子产品跨境贸易企业设计。采用响应式布局技术,确保电脑、平板、手机等设备访问时自动适配显示效果。数据实时同步管理,一次编辑全平台生效。查看源码 -
(自适应响应式)html5蓝色智能水表营销型网站pbootcms模板下载PbootCMS内核开发,为智能水表企业打造的营销型网站解决方案,本模板基于PbootCMS内核开发,为智能水表及相关行业企业设计,采用HTML5+CSS3技术构建,具有响应式布局。查看源码
| 分享笔记 (共有 篇笔记) |
