zoukankan      html  css  js  c++  java
  • 封装redis操作 php版本

    <?php
    
    namespace AppService;
    
    use AppServiceBaseService;
    use IlluminateSupportFacadesRedis;
    
    /*
     * redis操作相关方法
     */
    
    class RedisService extends BaseService {
    
        /**
         * 
         * @param string $key reids的get的key
         * @param string $class 待执行的方法的class    AppServiceAdminService
         * @param string $function  待执行的方法的function   getSupplyNum
         * @param array $parameters 待执行的方法的parameters  参数 ...$parameters   [] 数组自动绑定
         * @param int $survivalTime redis存储时间
         * $returnData 调用方法是否必须有数据
         * @return type
         * @throws Exception
         */
        public static function get(string $key, string $class = '', string $function = '', array $parameters = [], int $survivalTime = 3600, $returnData = true) {
            if (empty($key)) {
                throw new Exception('key不能为空');
            }
    
            $keyValue = Redis::get($key);
            if (empty($keyValue)) {
    
                if (!method_exists($class, $function)) {
                    throw new Exception($class . '此类的方法' . $function . '不存在');
                }
                /*
                 * 参数自动绑定,参数位置不能错
                 * $value 最好返回是数组,
                 */
                $value = $class::$function(...$parameters);
    //            p($value);
                if (empty($value) && $returnData) {
                    throw new Exception($class . '此类的方法' . $function . '返回数据为空,请检查调用方法');
                }
                Redis::set($key, json_encode($value));
                Redis::expire($key, $survivalTime);
                return json_encode($value);
            }
            return $keyValue;
        }
    
    }

    demo   AdminService

     //近一个月数据  
        public static function getMonthSaleOrderData($shop_id) {
    
            //近一个月订单总金额
            $saleOrderKey = 'MonthSaleOrder' . $shop_id;
    
            $data = RedisService::get($saleOrderKey, 'AppServiceAdminService', 'MonthSaleOrderData', [$shop_id]);
    
            return json_decode($data, true);
        }
    
        public static function MonthSaleOrderData($shop_id) {
            $time = get_lately_month_start_to_end();
    
            $query = SaleOrder::where('shop_id', $shop_id)->where('is_delete', 10)
                    ->where('create_time', '>=', $time['start_time'])
                    ->where('create_time', '<=', $time['end_time']);
            $saleOrderAmount = $query->sum('order_amount');
            $saleOrderNumber = $query->sum('order_number');
            $saleOrderCount = $query->count();
            $data = [
                'saleOrderAmount' => $saleOrderAmount,
                'saleOrderNumber' => $saleOrderNumber,
                'saleOrderCount' => $saleOrderCount,
            ];
            return $data;
        }
  • 相关阅读:
    齐次和线性
    数组指针/指针数组
    坐标转换矩阵
    【转】GMM与K-means聚类效果实战
    利用虚函数实现多态的方式:动态绑定
    类型限定符volatile
    《剑指offer》查找二维数组内元素 c++
    windows下使用命令行编译、链接C++源文件
    关于该博客的美化
    vimium快捷键修改
  • 原文地址:https://www.cnblogs.com/zx-admin/p/11106980.html
Copyright © 2011-2022 走看看