您现在的位置是:首页 > cms教程 > phpcms教程phpcms教程
phpcms操作数据库增删改查常用方法
武邦致2025-05-19phpcms教程已有人查阅
导读数据库的其他类继承的都是libs/class/model.class.php这里面有写好的操作数据库的常用方法
数据库的其他类继承的都是libs/class/model.class.php
这里面有写好的操作数据库的常用方法
1.增
delete($where)
3.改
update($data, $where = '')
4.查
这里面有写好的操作数据库的常用方法
1.增
insert($data, $return_insert_id = false, $replace = false)
/**
* 执行添加记录操作
* @param $data 要增加的数据,参数为数组。数组key为字段值,数组值为数据取值
* @param $return_insert_id 是否返回新建ID号
* @param $replace 是否采用 replace into的方式添加数据
* @return boolean
*/
insert($data, $return_insert_id = false, $replace = false)
union_listinfo($main_table, $secondary_table, $fields = '*', $where = '', $order = '', $page = 1, $pagesize = 20, $union_on='m.id=s.id',$limit='')
/**
* 两个表联合查询分页
* @param string $main_table 主表
* @param string $secondary_table 副表
* @param string $data 查询字段
* @param string $where 条件
* @param string $order 排序
* @param string $page 分页
* @param string $pagesize 每页记录数
* @return array
* @author:hans
*/
union_listinfo($main_table, $secondary_table, $fields = '*', $where = '', $order = '', $page = 1, $pagesize = 20, $union_on='m.id=s.id',$limit='')
2.删除delete($where)
/**
* 执行删除记录操作
* @param $where删除数据条件,不充许为空。
* @return boolean
*/
delete($where)3.改
update($data, $where = '')
/**
* 执行更新记录操作
* @param $data 要更新的数据内容,参数可以为数组也可以为字符串,建议数组。
*为数组时数组key为字段值,数组值为数据取值
*为字符串时[例:`name`='phpcms',`hits`=`hits`+1]。
*为数组时[例: array('name'=>'phpcms','password'=>'123456')]
*数组的另一种使用array('name'=>'+=1', 'base'=>'-=1');程序会自动解析为`name` = `name` + 1, `base` = `base` - 1
* @param $where更新数据时的条件,可为数组或字符串
* @return boolean
*/
update($data, $where = '')4.查
select($where = '', $data = '*', $limit = '', $order = '', $group = '', $key='')
/**
* 执行sql查询
* @param $where查询条件[例`name`='$name']
* @param $data 需要查询的字段值[例`name`,`gender`,`birthday`]
* @param $limit返回结果范围[例:10或10,10 默认为空]
* @param $order排序方式[默认按数据库默认方式排序]
* @param $group分组方式[默认为空]
* @param $key返回数组按键名排序
* @return array查询结果集数组
*/
final public function select($where = '', $data = '*', $limit = '', $order = '', $group = '', $key='') {
if (is_array($where)) $where = $this->sqls($where);
return $this->db->select($data, $this->table_name, $where, $limit, $order, $group, $key);
}
get_one($where = '', $data = '*', $order = '', $group = '')
/**
* 获取单条记录查询
* @param $where查询条件
* @param $data 需要查询的字段值[例`name`,`gender`,`birthday`]
* @param $order排序方式[默认按数据库默认方式排序]
* @param $group分组方式[默认为空]
* @return array/null 数据查询结果集,如果不存在,则返回空
*/
final public function get_one($where = '', $data = '*', $order = '', $group = '') {
if (is_array($where)) $where = $this->sqls($where);
return $this->db->get_one($data, $this->table_name, $where, $order, $group);
}
query($sql) 用query来执行sql,得到的结果需要遍历一次才是数组
/**
* 直接执行sql查询
* @param $sql查询sql语句
* @returnboolean/query resource如果为查询语句,返回资源句柄,否则返回true/false
*/
final public function query($sql) {
$sql = str_replace('phpcms_', $this->db_tablepre, $sql);
return $this->db->query($sql);
}
1
listinfo($where = '', $order = '', $page = 1, $pagesize = 20, $key='', $setpages = 10,$urlrule = '',$array = array(), $data = '*')查询多条记录并且分页,这里用到的分页和后台的分页是相同的样式(到后台看操作日志的分页),如果需要修改样式的话,需要赋值框架自己的分页,重命名后再修改,网上有很多例子。
/**
* 查询多条数据并分页
* @param $where
* @param $order
* @param $page
* @param $pagesize
* @return unknown_type
*/
final public function listinfo($where = '', $order = '', $page = 1, $pagesize = 20, $key='', $setpages = 10,$urlrule = '',$array = array(), $data = '*') {
$where = to_sqls($where);
$this->number = $this->count($where);
$page = max(intval($page), 1);
$offset = $pagesize*($page-1);
$this->pages = pages($this->number, $page, $pagesize, $urlrule, $array, $setpages);
$array = array();
if ($this->number > 0) {
return $this->select($where, $data, "$offset, $pagesize", $order, '', $key);
} else {
return array();
}
}
1
union_listinfo($main_table, $secondary_table, $fields = '*', $where = '', $order = '', $page = 1, $pagesize = 20, $union_on='m.id=s.id',$limit='')多表链接查询,类似tp里面的leftjoin,innerjoin 一般用于主表和附表链
public function union_listinfo($main_table, $secondary_table, $fields = '*', $where = '', $order = '', $page = 1, $pagesize = 20, $union_on='m.id=s.id',$limit='') {
/*获取记录总数*/
$query_count = "SELECT count(*) AS `total` FROM $main_table AS m INNER JOIN $secondary_table AS s ON $union_on WHERE $where";
$this->db->query($query_count);
$counts = $this->db->fetch_next();
$this->number = $counts['total'];
/*设置分页*/
$page = max(intval($page), 1);
$offset = $pagesize*($page-1);
$this->pages = pages($this->number, $page, $pagesize);
/*获取记录*/
$array = array();
if ($this->number > 0) {
$query = "SELECT $fields FROM $main_table AS m";
$query .= " INNER JOIN $secondary_table AS s ON $union_on";
$query .= " WHERE $where";
if($order) $query .= " ORDER BY $order";//排序
if($limit) $query .= " LIMIT $limit";
else $query .= " LIMIT $offset, $pagesize";
$this->db->query($query);
$data = array();
while($r = $this->db->fetch_next()) {
$data[] = $r;
}
return $data;
} else {
return array();
}
}
其他查询 目前还没用到:count($where = '')
/**
* 计算记录数
* @param string/array $where 查询条件
*/
final public function count($where = '') {
$r = $this->get_one($where, "COUNT(*) AS num");
return $r['num'];
}
insert_id()
/**
* 获取之后一次添加记录的主键号
* @return int
*/
final public function insert_id() {
return $this->db->insert_id();
}
affected_rows()
get_primary()
get_fields($table_name = '')
table_exists($table)
field_exists($field)
fetch_array()
/**
* 获取之后数据库操作影响到的条数
* @return int
*/
final public function affected_rows() {
return $this->db->affected_rows();
}
/**
* 获取数据表主键
* @return array
*/
final public function get_primary() {
return $this->db->get_primary($this->table_name);
}
/**
* 获取表字段
* @param string $table_name表名
* @return array
*/
final public function get_fields($table_name = '') {
if (empty($table_name)) {
$table_name = $this->table_name;
} else {
$table_name = $this->db_tablepre.$table_name;
}
return $this->db->get_fields($table_name);
}
/**
* 检查表是否存在
* @param $table 表名
* @return boolean
*/
final public function table_exists($table){
return $this->db->table_exists($this->db_tablepre.$table);
}
/**
* 检查字段是否存在
* @param $field 字段名
* @return boolean
*/
public function field_exists($field) {
$fields = $this->db->get_fields($this->table_name);
return array_key_exists($field, $fields);
}
final public function list_tables() {
return $this->db->list_tables();
}
/**
* 返回数据结果集
* @param $query (mysql_query返回值)
* @return array
*/
final public function fetch_array() {
$data = array();
while($r = $this->db->fetch_next()) {
$data[] = $r;
}
return $data;
}
本文标签:
很赞哦! ()
下一篇:phpcmsV9内容模型管理介绍
相关教程
图文教程
PHPCMS卸载PHPSSO的方法
PHPCMS不可卸载PHPSSO,因为PHPCMS会员功能是依赖PHPSSO,所以导致无法卸载PHPSSO,但是可以在安装的时候,使用第二种方式安装,并且只安装PHPCMS即可。
PHPCMSv9视频插件使用方法介绍
目前已经完成了播放器的自定义添加功能,功能类似phpcms2008,以模型的形式使用,简化为字段的开发,大家集思广益,将自己需要的功能详细说明下,"你心目中的视频模型" 。
PHPcms模块开发教程
由于工作关系,只能暂时放弃对mongodb的研究了,开始研究PHPcms,目前为止我已经基本完成了模块的开发,趁着周末来这里做个总结。我发现phpcms写的还不错
PHPCMS常用功能学习
1.碎片管理2.为了升级操作MY_ thinkphp为大写phpcms里面也是大写 然后继承如果加构造函数要调用一次父类的构造函数,较好在最上面调用
相关源码
-
帝国cms7.5自适应作文新闻资讯教育网站模板本模板基于帝国CMS7.5内核开发,为教育机构、培训学校等知识传播单位打造。通过自适应设计确保在手机、平板、电脑等设备上均能获得专业浏览体验查看源码 -
帝国CMS中小学生知识点试题练习题考试源码下载基于帝国CMS后台管理系统,支持在线修改联系信息、网站参数等配置,操作流程简洁明了。专注于中小学教育领域,集成知识点总结、试题练习、考试资讯等学习资源,为师生提供全面的在线学习支持与服务。查看源码 -
(PC+WAP)货物运输快递物流汽车贸易pbootcms模板下载为货运代理、汽车贸易及快递企业设计的全终端适配网站系统,整合运单追踪与车辆展示核心功能模块原生开发的DIV+CSS架构,支持WebP图像压缩技术。查看源码 -
自适应建材瓷砖卫浴大理石类pbootcms网站模板源码下载为建材瓷砖、卫浴瓷砖企业打造的高端响应式门户模板,基于PbootCMS内核深度开发。采用前沿HTML5自适应架构,无缝兼容手机端触控交互与PC端展示场景。查看源码 -
(自适应)简繁双语响应式服装服饰西装工装校服定制pbootcms模板本模板基于PbootCMS内核开发,为服装服饰行业量身打造,尤其适合西装定制、工装生产、校服订制等服装类企业使用。模板采用响应式布局设计,确保在手机、平板、电脑查看源码 -
(PC+WAP)五金机械设备营销型模板下载带在线留言为机械设备制造商设计的营销型模板,集成产品参数对比系统、产品展示模块和询价管理功能。采用PbootCMS开发内核,PHP7+运行环境。手工编写语义化HTML5结构,CSS3动画优化交互体验。查看源码
| 分享笔记 (共有 篇笔记) |
