tablePrefix ='tab_'; /* 执行构造方法 */ parent::__construct($name, $tablePrefix, $connection); } /** * 记录列表 * @param integer $p 页码 * @param array $map 条件数组 * @param string $fields 字段列表 * @param string $order 排序 * @param integer $row 每页数量 * @return array 结果数据集 * @author 鹿文学 */ public function lists($p=1,$map=array(),$fields=true,$order='online_time desc',$row=10) { $page = intval($p); $page = $page ? $page : 1; //默认显示第一页数据 $user = D('User')->getLoginInfo(); if(is_array($user)){ $map['status'] = array('gt',0); $map['user_id'] = $user['user_id']; $lists = $this->alias('m')->field($fields) ->where($map)->page($page,$row)->order($order)->select(); $count = $this->alias('m')->where($map)->count(); } if(is_array($lists)) { $data['lists'] = $lists;$data['status']=1; if($count > $row){ $data['total'] = ceil($count/$row); } else { $data['total']=1; } } else { $data['lists']='';$data['total'] = 1;$data['status'] = 0; } $data['current'] = $page; return $data; } /** * 新增或更新一个记录 * @param array $data 手动传入的数据 * @return boolean fasle 失败 , int 成功 返回完整的数据 * @author 王贺 */ public function update($data = null){ /* 获取数据对象 */ $data = $this->token(false)->create($data); if(empty($data)){ return false; } /* 添加或新增基础内容 */ if(empty($data['id'])){ //新增数据 $id = $this->add($data); //添加基础内容 if(!$id){ $this->error = '提现失败,请重新提交'; return false; }else{ $data['id'] = $id; } } else { //更新数据 $status = $this->save(); //更新基础内容 if(false === $status){ $this->error = '更新基础内容出错!'; return false; } } return $data; } /** * 创建时间不写则取当前时间 * @return int 时间戳 * @author huajie */ protected function getCreateTime(){ $create_time = I('post.create_time'); return $create_time?strtotime($create_time):NOW_TIME; } /** * 创建订单号 * @return int 时间戳 * @author huajie */ protected function get_order_number() { $order_number = I('post.order_number'); return $order_number?$order_number:'WG_'.date('Ymd').date('His').sp_random_string(4);; } /** * 获取商品总数 * @param array $map 条件数组 * @return integer 总数 * @author 鹿文学 */ public function total($map) { return $this->where($map)->count(); } /** * 商品详情 * @param integer $id 商品编号 * @return array 结果数据集 * @author 鹿文学 */ public function detail($id=0) { if(is_numeric($id) && $id > 0) { $map['m.id'] = $id; $data = $this->merchandise_info($map); } return $data; } /** * 商品详情 * @param integer $id 商品编号 * @return array 结果数据集 * @author 鹿文学 */ public function sale_detail($id=0) { if(is_numeric($id) && $id > 0) { $map['m.id'] = $id; $map['m.status']=3; $map['m.online_time'] = ['gt',0]; $data = $this->merchandise_info($map); } return $data; } /** * 商品详情 * @param integer $id 商品编号 * @return array 结果数据集 * @author 鹿文学 */ public function deal_detail($id=0) { if(is_numeric($id) && $id > 0) { $map['m.id'] = $id; $map['m.status']=1; $data = $this->merchandise_info($map); } return $data; } private function merchandise_info($map) { return $this->alias('m')->field('m.id,m.title,m.content,m.status,m.screenshot,m.online_time,m.server_name,m.price,m.day,m.accumulation,m.small_account,g.relation_game_id,g.game_name,g.game_size,g.game_type_name,g.sdk_version,g.down_port,g.add_game_address,g.ios_game_address') ->join('tab_game as g on(g.id = m.game_id) ') ->where($map)->find(); } /** * 商品信息 * @param integer $id 商品编号 * @return array 结果数据集 * @author 鹿文学 */ public function info($id=0) { if(is_numeric($id) && $id > 0) { $map['m.id'] = $id; $map['m.status'] = 3; $map['m.online_time'] = ['gt',0]; $data = $this->alias('m')->field('m.id,m.title,m.price,m.game_name,m.screenshot') ->where($map)->find(); } return $data; } /** * 商品购买需要的信息 * @param integer $id 商品编号 * @return array 结果数据集 * @author 鹿文学 */ public function buy_info($id=0) { if(is_numeric($id) && $id > 0) { $map['m.id'] = $id; $map['m.status'] = 3; $data = $this->alias('m')->field('m.id,m.price,m.small_id,m.small_account,m.user_id as seller_id,m.user_account as seller_account,m.game_id') ->where($map)->find(); } return $data; } }