• PHP代码篇(三)--常用方法


    模块下不间断更新,PHP常用方法,欢迎留言!

    一、递归删除指定目录下所有文件及文件夹
    /**
     * 递归删除指定目录下所有文件及文件夹
     * @param unknown $path,删除路径
     */
    function deleteFileWay($path)
    {
        //如果是目录则继续
        if(is_dir($path)){
            //扫描一个文件夹内的所有文件夹和文件并返回数组
            $info = scandir($path);
            foreach($info as $k=>$v){
                 //排除目录中的.和..
                if($v != '.' && $v != '..'){
                    if(is_dir($path.$v)){
                        //子目录中操作删除文件夹和文件
                        deleteFileWay($path.$v.'/');
                        //目录清空后删除空文件夹
                        @rmdir($path.$v.'/');
                    }else{
                        //如果是文件直接删除
                        @unlink($path.$v);
                    }
                }
            }
        }
    }
    
    /**
     * [result14 description]
     * 查找会员下面所有盟主
     * 参数$uid会员id
     * 返回
     * 'status'=>0,没有下级盟主
     * 'status'=>1,'data'=>下级盟主id,数组类型
     */
    function result14($uid){
        $cancel_user_list=$uid.',';//下级所有盟主列表列表,用于sqlin语句
        $crt_level_user=pdo_getall('nets_hjk_members', array('from_uid' => $uid), array('type','memberid','level'));
        if (empty($crt_level_user)) {
            return array('status'=>0,'hint'=>"没有需要变更的下级1");
        }
        while (!empty($crt_level_user)) {
            //从当前用户中提取memberid,用于下一次取下级用户
            $crt_level_user_for_sqlin='';
            $crt_level_leader_for_sqlin='';
            foreach ($crt_level_user as $value) {
                $crt_level_user_for_sqlin .= $value['memberid'].',';
                    //遍历crt_level_user中所有的行,取出盟主的memberid放在$crt_level_leader_for_sqlin中
                if ($value['type'] == 1) {
                    $crt_level_leader_for_sqlin .= $value['memberid'].',';
                }
            }
            $cancel_user_list .= $crt_level_leader_for_sqlin;
            //获取当前层级下级用户
            if(!empty($crt_level_user_for_sqlin)){
                $crt_level_user_for_sqlin=substr($crt_level_user_for_sqlin,0,strlen($crt_level_user_for_sqlin)-1);
            }
            $crt_level_user=pdo_fetchall("SELECT ex.memberid,ex.type FROM ".tablename('nets_hjk_members')." AS ex where from_uid in(". $crt_level_user_for_sqlin.") ");
        }
        $junior_user_list = '';
        $cancel_user_list = substr($cancel_user_list,0,strlen($cancel_user_list)-1);
        $cancel_user_list_arr = explode(",",$cancel_user_list);
        //当下会员下级所有的盟主,数组
        $cancel_user_list_arr = array_splice($cancel_user_list_arr,1);
        if (empty($cancel_user_list_arr)) {
            return array('status'=>0,'hint'=>"没有需要变更的下级2");
        }else{
            return array('status'=>1,'data'=>$cancel_user_list_arr);
        }
    }

    二、数据库常用操作

    //插入一条数据
    INSERT INTO ims_stat_rule (rid,hit) VALUES (351,990);
    
    //删除一条数据
    DELETE FROM ims_nets_hjk_applyfor WHERE member_id = 49483;
    
    //修改一条数据
    update ims_nets_hjk_members set level = 4 where id = 100248;
    
    //查询数据
    select * from ims_nets_hjk_members where memberid = 18978;
    
    //格式化时间戳
    FROM_UNIXTIME(M1.created_at,'%Y-%m-%d %H:%i:%s') AS created_at;
    
    //SQL中IF的用法,如果表M1时间戳为0则默认为'/',反之则进行格式化时间戳处理
    IF(M1.finish_time = 0,'/',FROM_UNIXTIME(M1.finish_time,'%Y-%m-%d %H:%i:%s')) AS finish_time

     三、ThinkPHP5.0常用操作

    //查询区间内
    $device_string = $db->table('ims_nets_hjk_devices')
                        ->where('device_id',['>=',$k],['<=',$j],'AND')
                        ->where('status',0)
                        ->field('device_id')
                        ->limit(50)
                        ->select();
    
    // 如下为CASE的用法-----------------------------
    $level = Db::query("SELECT SUM(1) AS '全部用户',SUM(CASE WHEN type=1 AND level= 0 THEN 1 ELSE 0 END) AS '店主',SUM(CASE WHEN type=1 AND level= 1 THEN 1 ELSE 0 END) AS '高级店主',SUM(CASE WHEN type=1 AND level= 2 THEN 1 ELSE 0 END) AS '特约店主',SUM(CASE WHEN type=0 THEN 1 ELSE 0 END) AS '普通用户',SUM(CASE WHEN is_partner=1 THEN 1 ELSE 0 END) AS '合伙人',SUM(CASE WHEN is_insider=1 THEN 1 ELSE 0 END) AS '内部',SUM(CASE WHEN is_city_agent=1 THEN 1 ELSE 0 END) AS '市级代理' FROM ims_nets_hjk_members");
    SELECT SUM(CASE WHEN
                         pay_status = 1 AND
                         date_format(from_UNIXTIME(`pay_time`),'%Y-%m-%d') = date_format(now(),'%Y-%m-%d') THEN 1 ELSE 0 END
                         ) AS S1,
                     SUM(CASE WHEN
                         pay_status = 1 AND
                         date_format(from_UNIXTIME(`pay_time`),'%Y-%m-%d') = date_format(now(),'%Y-%m-%d') THEN point ELSE 0 END
                         ) AS S2,
                     SUM(CASE WHEN
                         pay_status = 1 AND
                         order_status = 0 THEN 1 ELSE 0 END
                         ) AS S3
    FROM ims_integral_order;
    
    // 优化一个四表联查,以会员表作为临时表--------------------------
    $list = Db::query("
                         SELECT
                         M1s.*, M2.avatar AS avatar_is,
                         M2.avatar AS avatar_is,M2.nickname AS nickname_is,M2.pid AS pid_is,
                         M3.integral,M3.asset,M3.wallet,
                         FROM_UNIXTIME(M4.addTime,'%Y-%m-%d %H:%i:%s') AS addTime
                         FROM
                         (
                             SELECT
                                 memberid,pid,avatar,nickname,FROM_UNIXTIME(created_at,'%Y-%m-%d %H:%i:%s') AS created_at,level,type,is_city_agent,is_partner,is_insider,realname,mobile,from_uid
                             FROM
                                 ims_nets_hjk_members AS M1
                             WHERE ".$whes."
                             ORDER BY
                                 created_at DESC
                             LIMIT ".(($pindex - 1) * $psize).",". $psize."
                         ) AS M1s
                         LEFT JOIN ims_nets_hjk_members AS M2 ON M1s.from_uid = M2.memberid
                         LEFT JOIN ims_mc_members AS M3 ON M1s.memberid = M3.uid
                         LEFT JOIN t_fans_log AS M4 ON M1s.memberid = M4.fans_memberId
                         ");
    
    //TP自加和自减
    $res = $this->where('single','gt',0)
        ->update([
            'red_fee'=>['INC',$fee],//自加
            'create_time'=>time(),
            'count'=>['DEC',1],//自减
             ]);
    
    //TP大于或者小于
    $res = $this->where([
          ['status','=',1],
          ['page_id','>',0]
          ]);
    
    //DB操作批量插入
    $res = $db->table('ims_nets_hjk_sogo_licence')->insertAll($sogo_licence);
    
    //查询指定会员已激活的设备,并且不在ims_nets_hjk_sogo_equipment表里面,EXISTS用法
    $list = $db->query("SELECT s_id FROM `ims_nets_hjk_devices` 
              WHERE active_member_id = ".$uid." 
              AND `status` = 1
              AND NOT EXISTS 
                (SELECT s_id FROM ims_nets_hjk_sogo_equipment WHERE s_id = ims_nets_hjk_devices.s_id )
    
    //打印SQL语句
    ->buildSql();

    四、ThinkPHP5.0常用操作

    //模拟url传递数组
    $url = 'http://niushop.jingjinglego.com/index.php?s=/admin/We7Config/addIndexAd&type=2&adList[0][sort]=456&adList[0][img]=upad/test/1e.jpg&adList[0][outerUrl]=www.bai.com&adList[0][source]=1&adList[1][sort]=456&adList[1][img]=upad/test/1e.jpg&adList[1][outerUrl]=www.bai.com&adList[1][source]=1';
    
    //调用请求类request写法,接受数组
    $ids = request->post('ids/a');
    
    //获取参数
    use thinkRequest;
    $request = Request::instance();
    $method = $request->method();//获取上传方式
    $request->param();//获取所有参数,最全
    $get = $request->get();//获取get上传的内容
    $post = $request->post();//获取post上传的内容
    $request->file('file')//获取文件
    
    //错误和正确提示及跳转error/success
    $this->error("抱歉你不是最帅的人", __URL__ . "/wap/We7Store/storeManagement");
    
    // 锁定跳转,url重定向
    $redirect = __URL(__URL__ . "/wap/login/userlock");
    $this->redirect($redirect); 

     四、检查字符串是否是URL

    //判断是否是url
    function is_url($v){
        $pattern="#(http|https)://(.*.)?.*..*#i";
        if(preg_match($pattern,$v)){ 
            return true; 
        }else{ 
            return false; 
        } 
    }
  • 相关阅读:
    appium 滑动屏幕
    appium 根据属性名获取属性值 特殊情况 element.get_attribute('name')相当于element.get_attribute('content-desc')或element.get_attribute('text')
    appium 获取元素的内容 获取元素的位置和大小
    appium 点击 输入 清空 ;异常处理 当输入中文 ,没有效果时,需要前置代码里加两行代码
    appium 隐式 查找元素
    appium 过滤出带有‘设’的文本
    appium 批量找元素
    通过id class xpath 找元素
    随笔
    spring 事务传播特性
  • 原文地址:https://www.cnblogs.com/camg/p/11202773.html
Copyright © 2020-2023  润新知