<?php   if ( ! defined('BASEPATH')) exit('No direct script access allowed');
/**
* SEO管理系统 -- 公用模型
* @author yangheping
* @since 2013/11/11
*/
class Common_model extends CI_Model{ public function __construct()
{
parent::__construct();
$this->load->database();
} /**
* 分页数据查询
* 功能:
* 一、查询条件分页总数
* 二、查询条件分页数据信息
* @param string $table 表名称
* @param array $param 查询条件:
* array($key => $val) $key为要操作的字段,$val为要操作的值
* @param string $type 为total返回总数,range为返回对应数据
* @param string $show_field 为需要查询的字段
* @param array $order 排序条件:
* array($key => $val)
* $key为排序依据的字段,
* $val为排序的方式【asc (升序,默认)或 desc(降序), 或 random(随机)】
* @return int 或 array
*/
public function pageData($table = '', $param = array(), $type = 'total', $show_field = '*', $order = array())
{ if(empty($table))
{
return FALSE;
} $limit = (int)$param['limit'];
$page = (int)$param['page']; //开始查询的ID,在CI分页中 $not_table_column_arr = array('limit', 'page'); //处理查询条件的组合
if (!empty($param) && is_array($param)) {
foreach($param as $key => $val){
if(!empty($val) && ($val != 'n') && !in_array($key, $not_table_column_arr))
{
$this->db->where($key, $val);
}
}
} //排序规则的组合
if (!empty($order) && is_array($order))
{
foreach ($order as $key => $val)
{
$this->db->order_by($key, $val);
}
}else{ //默认按照此表的主键倒序
$primary_arr = $this->getPrimary('hf_seo', $table);
if(!empty($primary_arr))
{
$this->db->order_by($primary_arr[0]->COLUMN_NAME, 'DESC');
}
} $this->db->select($show_field)
->from($table); //求条件下总数
if( $type == 'total' )
{
return $this->db->count_all_results();
} //返回当前分页数据
if( $type == 'range' )
{
//分页边界值 设置
$limit_start = $page <= 1 ? 0 : ($page-1)*$limit;
$this->db->limit($limit, $limit_start);
$query = $this->db->get();
// return $this->db->last_query(); //返回组合后的SQL语句
return $query->result_object();
} return FALSE;
} /**
* 新增信息
* @param string $table 表名称
* @param array $param 数据变量
* @return INT ID
*/
public function add($table = '', $param = array())
{
if(empty($table) || !is_array($param) || empty ($param)){
return FALSE;
} //写入数据表
$this->db->insert($table, $param); //返回记录ID
return $this->db->insert_id();
} /**
* 更新分类信息
* @param string $table 表名称
* @param string $primary 表主键
* @param int $id 分类ID
* @param array $param 更新的数据
* @return type
*/
public function update($table = '', $primary = '', $id = 0, $param = array())
{
if(empty($table) || empty($primary) || empty($param) || empty($id))
{
return FALSE;
} $id = (int)$id;
$this->db->where($primary, $id)
->limit(1)
->update($table, $param);
return $this->db->affected_rows();
} /**
* 删除指定ID记录
* @param string $table 表名称
* @param string $primary 表主键
* @param array $id 分类ID
* @return int
*/
public function delete($table = '', $primary = '', $id = array())
{ if(empty($table) || empty($primary) || empty($id))
{
return FALSE;
} $this->db->where_in($primary, $id)
->delete($table); return $this->db->affected_rows();
} /**
* 多字段条件查询数据
* @param string $table 表名称
* @param array $param 查询条件:
* array($key => $val) $key为要操作的字段,$val为要操作的值
* @param int $limit 数据数目
* @param int $offset 开始位置
* @param string $show_field 要显示字段
* @param array $order 排序条件:
* array($key => $val)
* $key为排序依据的字段,
* $val为排序的方式【asc (升序,默认)或 desc(降序), 或 random(随机)】
* @return array|boolean
*/
public function search($table = '', $param = array(), $limit = null, $offset = null, $show_field = '*', $order = array())
{
if(empty($table))
{
return FALSE;
} $this->db->select($show_field); if (is_array($param) && count($param) > 0)
{
foreach ($param as $key => $val)
{
if (!empty($key))
{
$this->db->where($key, $val);
}
}
} if (!empty($order) && is_array($order))
{
foreach ($order as $key => $val)
{
$this->db->order_by($key, $val);
}
} if( is_numeric($limit) )
{
$limit = intval($limit);
} else {
$limit = null;
} if( is_numeric($offset) )
{
$offset = intval($offset);
} else{
$offset = null;
} $query = $this->db->get($table, $limit, $offset);
return $query->num_rows() > 0 ? $query->result_object() : FALSE; return FALSE;
} /**
* 获取表的主键
* @param string $database 数据库名称
* @param strting $table 表名称
*/
public function getPrimary($database = '', $table = '')
{
if(empty($database) || empty($table))
{
return FALSE;
} $this->db->select('c.COLUMN_NAME')
->from('INFORMATION_SCHEMA.TABLE_CONSTRAINTS AS t')
->join('INFORMATION_SCHEMA.KEY_COLUMN_USAGE AS c', 't.TABLE_NAME = c.TABLE_NAME' , 'left')
->where('t.TABLE_SCHEMA', $database)
->where('t.TABLE_NAME', $table)
->where('t.CONSTRAINT_TYPE', 'PRIMARY KEY'); $query = $this->db->get();
return $query->result_object();
} } /* End of file Common_model.php */
/* Location: ./application/models/admin/Common_model.php */

CI公用模型的更多相关文章

  1. ci公共模型类

    我们都知道,操作数据库的方法都写在模型中.但是一般情况下,一张表往往至少对应4个操作,也就是所谓crud.那么如果20张表,所对应的模型方法,就达到了80个,重复的操作显然这已经是一个体力活儿. 那么 ...

  2. CI框架(一)

    CI工作流程:        所有的入口都从根目录下的index.php进入,确定应用所在目录后,加载 codeigniter/CodeIgniter.php 文件,该文件会顺序加载以下文件执行整个流 ...

  3. CI框架 简介

    CI工作流程:        所有的入口都从根目录下的index.php进入,确定应用所在目录后,加载 codeigniter/CodeIgniter.php 文件,该文件会顺序加载以下文件执行整个流 ...

  4. [深度概念]·Attention Model(注意力模型)学习笔记

    此文源自一个博客,笔者用黑体做了注释与解读,方便自己和大家深入理解Attention model,写的不对地方欢迎批评指正.. 1.Attention Model 概述 深度学习里的Attention ...

  5. 学习codeIgniter的一点小感受

    用CI好几天了,最终还是放弃用CI做完整的项目,感觉CI在前后端的交互上还比较差,比如说用户表单验证,仍然是需要把数据提交给服务器之后才能显示逻辑判断的结果.而这一点明显是相对落后了. 但不可否认CI ...

  6. Gartner容器市场指南中国语境:容器成为新常态,灵雀云等本地厂商在选择中占据优势

    在2019年2月“ China Summary Translation: 'Market Guide for Container Management Software'”的报告中,Gartner认为 ...

  7. Unity中资源打包成Assetsbundle的资料整理

    最近在研究Unity中关于资源打包的东西,网上看了一堆资料,这里做个整合,说整合,其实也就是Ctrl-C + Ctrl-V,不是原创 首先为了尊重原创,先贴出原创者的文章地址: http://blog ...

  8. Unity资源Assetbundle

    转  Unity资源打包之Assetbundle 本文原创版权归 csdn janeky 所有,转载请详细注明原创作者及出处,以示尊重! 作者:janeky 原文:http://blog.csdn.n ...

  9. Unity资源打包之Assetbundle

    转  Unity资源打包之Assetbundle 本文原创版权归 csdn janeky 所有,转载请详细注明原创作者及出处,以示尊重! 作者:janeky 原文:http://blog.csdn.n ...

随机推荐

  1. HashSet和SortSet对比--c#学习笔记

    微软在 .NET 3.5 新增了一个 HashSet 类,在 .NET 4 新增了一个 SortedSet 类. .NET Collection 函数库的 HashSet.SortedSet 这两个泛 ...

  2. Vue 响应式属性

    本文参考自:https://www.w3cplus.com/vue/vue-reactivity-and-pitfalls.html 1.概述 当创建一个Vue实例时,每个数据属性.组件属性等都是可以 ...

  3. Action window Flags

    Action window 主要字段使用 含义     target 值 作用 current 当前窗口 new 新窗口 inline 内联编辑 fullscreen 全屏 main 当前窗口的主动作 ...

  4. 多媒体层预览(Media Layer OverView)

    音频模块位于多媒体层里.多媒体层包含了图形.音频.视频三种技术.这三种技术会给你带来声觉.视觉上的良好体验. 来看看ios的结构体系以及媒体层上的内容:                         ...

  5. EMC机理------串扰

    转:电子工程师不得不知道的EMC机理------串扰(韬略科技EMC) 串扰是信号完整性中最基本的现象之一,在板上走线密度很高时串扰的影响尤其严重.我们知道,线性无缘系统满足叠加定理,如果受害线上有信 ...

  6. Lua学习三----------Lua数据类型

    © 版权声明:本文为博主原创文章,转载请注明出处 Lua数据类型 - Lua是动态类型语言,不需要为变量定义类型,只需要为变量赋值 - Lua有8中基本数据类型:nil.boolean.number. ...

  7. Laravel 5.4的本地化

    简介 Laravel 的本地化功能提供方便的方法来获取多语言的字符串,让你的网站可以简单的支持多语言. 语言包存放在 resources/lang 目录下的文件里.在此目录中应该有应用对应支持的语言并 ...

  8. jQuery--基础(查询标签)

    浅谈jQuery使用背景 jQuery是使用原生js写成的一个库,使用简单,提高开发效率.在用js冗杂的代码解决的问题中,大部分都可以用jQuery来快速解决. 例如: js中查询网页中ID为&quo ...

  9. static修饰内部类

    创建内容类的方式通过外部类的实例对象来创建 public class AA { int a =1; class BB { int b=3 ; } public static void main(Str ...

  10. 摩根大通银行被黑客攻克, ATM机/网银危在旦夕,winxp退市灾难来临了

    winxp4月退市到如今还不到半年,就出现故障了 7600多万个消费者银行账户被黑.此外还有700万个小企业账户的信息也被黑客窃取,这个算不算灾难呢?假设等到银行业彻底崩溃,资金彻底丧失,那不仅仅是灾 ...