duanbichou4942 2016-08-21 01:43
浏览 44
已采纳

Laravel与条件有很多很多关系

I have 4 tables users, opportunities, level_translations and levels

users
id, name, email

opportunities
id, client_name, user_id, total_price

levels
id, min, max

level_translations
id, name, description, locale, level_id

I want to get level name in current locale for given user id .. i'm using laravel-translatable package to localize my application

to get level it should be something like this

select * from levels where sum(opportunities.total_price) < levels.max and sum(opportunities.total_price) > levels.min 
  • 写回答

1条回答 默认 最新

  • douliaodun9153 2016-08-24 00:47
    关注

    I found a solution. my solution contain tow parts
    first part
    creating a MYSQL Function, i call it sumUserOwnopportunities(USERID)

        DELIMITER $$
    CREATE  FUNCTION `sumUserWonOpportunities`(USERID INT) 
     RETURNS double
    BEGIN
         DECLARE TOTAL_SUM DOUBLE DEFAULT 0;
         SELECT SUM(opportunities.total_price) from opportunities 
         WHERE opportunities.user_id=USERID AND (opportunities.status=1 OR opportunities.status=2) INTO TOTAL_SUM;
            RETURN TOTAL_SUM;
    END$$
    DELIMITER ;
    

    second part
    in User model

    function level(){
       return  Level::where(function ($q){
                $q->where("min","<",DB::raw(" sumUserWonOpportunities($this->id)"))
                ->where("max",">",DB::raw(" sumUserWonOpportunities($this->id)"));
            })->first();
    }
    

    now I can call

    $user=User::find(1);
    $level=$user->level()->name;// it will return level name in current locale 
    

    I hope this useful.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么