table.class.php 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. <?php
  2. /**
  3. * 数据库表抽象类
  4. *
  5. * 定义必须实现的抽象方法
  6. * 定义可以继承的方法,提高table层的书写效率
  7. *
  8. * @createtime 2018/03/01
  9. * @author 空竹
  10. * @copyright 芝麻开发(http://www.zhimawork.com)
  11. */
  12. abstract class Table {
  13. protected $table_name = '';//表名,不带前缀,前缀在config中定义
  14. protected $table_id = '';//指定ID字段名称,必须
  15. protected $table_status = '';//指定状态字段名称,如果有
  16. protected $table_order = '';//指定排序字段名称,如果有
  17. protected $pdo;
  18. protected $table_fullname;
  19. protected $table_struct;
  20. function __construct(){
  21. //初始数据库连接PDO
  22. global $mypdo;
  23. $this->pdo = $mypdo;
  24. $table_prefix = $this->pdo->prefix;
  25. //数据库全名
  26. $this->table_fullname = $table_prefix . $this->table_name;
  27. //数据库结构
  28. $this->table_struct = $this->struct();
  29. }
  30. ////////////////////////////////////////////////////
  31. /**************抽象方法,子类必须实现**************/
  32. ////////////////////////////////////////////////////
  33. //数据库结构
  34. //完整展示数据库所有字段及其含义
  35. //映射字段名称提供给其他层使用,不对外暴露数据库字段
  36. abstract protected function struct();
  37. //增
  38. //@param $attr array -- 键值同struct()返回的数组
  39. abstract public function add($attr);
  40. //获取列表(分页)
  41. //$count、$page和$pagesize都为0时,返回全部结果(适用于无需分页的情况)
  42. //
  43. //@param $filter array -- 过滤条件,格式见Table::filterToWhere
  44. //@param $count -- 0:返回列表 1:返回结果数量
  45. //@param $page -- 当前第几页
  46. //@param $pagesize -- 每页数量
  47. abstract public function getList($filter = array(), $count = 0, $page = 0, $pagesize = 0);
  48. ///////////////////////////////////////////////////////////////
  49. /**************非抽象方法,用于继承,也可以重载***************/
  50. ///////////////////////////////////////////////////////////////
  51. //获取详情
  52. public function getInfoById($id){
  53. //查询语句必须用sql_check_input检查参数
  54. $id = $this->pdo->sql_check_input(array('number', $id));
  55. $sql = "select * from ". $this->table_fullname ." where ". $this->table_id ." = $id limit 1";
  56. $rs = $this->pdo->sqlQuery($sql);
  57. $r = array();
  58. if($rs){
  59. foreach($rs as $key => $val){
  60. $r[$key] = $this->dataToAttr($val);
  61. }
  62. return $r[0];
  63. }else{
  64. return $r;
  65. }
  66. }
  67. //删
  68. public function del($id){
  69. $where = array(
  70. $this->table_id => array('number', $id)
  71. );
  72. return $this->pdo->sqldelete($this->table_fullname, $where);
  73. }
  74. //--------------------------------------------------
  75. //------------未实现的常见方法,便于重载------------
  76. //--------------------------------------------------
  77. //改
  78. //@param $attr 数组,键值参考add()
  79. public function edit($id, $attr){}
  80. //修改指定字段
  81. public function update($id, $attrs)
  82. {
  83. $params = array();
  84. foreach ($attrs as $key => $value) {
  85. //$type = self::getTypeByAttr($key);
  86. $params[$this->table_name.'_'.$key] = array('string', $value);
  87. }
  88. //where条件
  89. $where = array( $this->table_id => array("number", $id));
  90. //返回结果
  91. $r = $this->pdo->sqlupdate($this->table_fullname, $params, $where);
  92. return $r;
  93. }
  94. //--------------------------------------------------
  95. //------------依赖于字段设置的常见方法,可以重载----
  96. //--------------------------------------------------
  97. //单独修改状态
  98. public function updateStatus($id, $status){
  99. $where = array(
  100. $this->table_id => array('number', $id)
  101. );
  102. $param = array(
  103. $this->table_status => array('number', $status)
  104. );
  105. return $this->pdo->sqlupdate($this->table_fullname, $param, $where);
  106. }
  107. //单独修改排序
  108. public function updateOrder($id, $order){
  109. $where = array(
  110. $this->table_id => array('number', $id)
  111. );
  112. $param = array(
  113. $this->table_order => array('number', $order)
  114. );
  115. return $this->pdo->sqlupdate($this->table_fullname, $param, $where);
  116. }
  117. //--------------------------------------------------
  118. //------------其他方法------------------------------
  119. //--------------------------------------------------
  120. //从数据库取出的数据转化键值后输出
  121. protected function dataToAttr($data){
  122. $r = array();
  123. foreach($this->table_struct as $k => $v){
  124. $r[$k] = $data[$v];
  125. }
  126. return $r;
  127. }
  128. //把filter转化为where子句
  129. //仅支持最常见的=和like,不支持其他符号
  130. //@param $filter array 键值要符合struct()中的定义
  131. //----参数示例----
  132. # $filter = array(
  133. # 'account' => array('abc', '=s'),//精确搜索
  134. # 'title' => array('xyz', '%s'),//模糊搜索
  135. # 'desc' => 'test',//不指定则为精确搜索
  136. # 'type' => 1
  137. # )
  138. //----参数示例结束----
  139. protected function filterToWhere($filter){
  140. $struct = $this->table_struct;
  141. $where = ' where 1=1 ';
  142. foreach($filter as $k => $v){
  143. if(is_array($v)){
  144. $val = $v[0];
  145. $operator = $v[1];
  146. }else{
  147. $val = $v;
  148. $operator = '=s';
  149. }
  150. $field_name = $struct[$k];
  151. if($operator == '=n'){//数字
  152. $val = $this->pdo->sql_check_input(array('number', $val));
  153. $where .= " and $field_name = $val ";
  154. }
  155. if($operator == '=s'){//字符串,精确搜索
  156. $val = $this->pdo->sql_check_input(array('string', $val));
  157. $where .= " and $field_name = $val ";
  158. }
  159. if($operator == '>num'){//大于数字
  160. $val = $this->pdo->sql_check_input(array('number', $val));
  161. $where .= " and $field_name > $val ";
  162. }
  163. if($operator == '<num'){//小于数字
  164. $val = $this->pdo->sql_check_input(array('number', $val));
  165. $where .= " and $field_name < $val ";
  166. }
  167. if($operator == '%s'){//字符串,模糊搜索
  168. $val = '%'.$val.'%';
  169. $val = $this->pdo->sql_check_input(array('string', $val));
  170. $where .= " and $field_name like $val " ;
  171. }
  172. if($operator == '=n_arr'){//or 连接的数字数组
  173. $where .= " and (";
  174. $first = true;
  175. foreach ($val as $item) {
  176. if ($first) {
  177. $where .= " $field_name = $item ";
  178. $first = false;
  179. } else {
  180. $where .= " or $field_name = $item ";
  181. }
  182. }
  183. $where .= ") ";
  184. }
  185. if($operator == '=date'){//时间戳在当天
  186. $val = $this->pdo->sql_check_input(array('number', $val));
  187. if (empty($val)) {
  188. break;
  189. }
  190. $begin = $val; //不分时区
  191. $end = $val + 24*60*60;
  192. $where .= " and ($field_name >= $begin and $field_name < $end) ";
  193. }
  194. if($operator == 'date2date'){//时间戳在两天之间
  195. if (!empty($val[0])) {
  196. $begin = $val[0] - 8*60*60; //东8时区
  197. $where .= " and $field_name >= $begin ";
  198. }
  199. if (!empty($val[1])) {
  200. $end = $val[1] + 16*60*60;
  201. $where .= " and $field_name < $end ";
  202. }
  203. }
  204. if($operator == 'id_in_arr'){//id在数组中
  205. $where .= " and (1=0 ";
  206. foreach ($val as $tempId) {
  207. $tempId = $this->pdo->sql_check_input(array('number', $tempId));
  208. $where .= " or $field_name=$tempId ";
  209. }
  210. $where .= ") ";
  211. }
  212. }
  213. return $where;
  214. }
  215. }
  216. ?>