thinkphp5 查询的时候,需要用到关联数据表中的一个字段fare,如果没有关联,则默认该字段为0,继续参与下面的计算
taotaoit ThinkPHP5.1 2025-11-10 11 0
关于本站

“最难不过坚持”

本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作

有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339

8731001 2716 39
最新评论
https://jueru.net/
评 留言
:weixiao:
评 留言
:shuijiao: :weiqu: :zhenbang: :leng:
评 留言
:yiwen: :yiwen: :yiwen: :yiwen:
评 EasySass: could not generate CSS file. See Output panel for details.
这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
评 TP6模型事件-查询后onAfterRead不好用
文章标签更多
ThinkPHP (260)
Mysql (59)
DedeCms (33)
jQuery (74)
证件照 (1)
setInc (4)
setDec (4)
onclick (5)
打开边栏(ESC) 关闭边栏(ESC)

thinkphp5 查询的时候,需要用到关联数据表中的一个字段fare,如果没有关联,则默认该字段为0,继续参与下面的计算

完整代码:

// 构建查询
    $list = Db::name('goods') // 替换为你的实际表名
        ->alias('g')
        ->leftJoin("ship.delivery d", "d.id = g.deliveryId")
        ->field("g.*,d.fare,
            CASE 
                WHEN currency = 1 THEN 
                    faBuyPrice * (1 + 0.1 + jpTaxRate + 0.05) * 1.5 + (IFNULL(d.fare, 0) * 1.25)
                ELSE 
                    faBuyPrice * {$exchange} * (1 + 0.1 + jpTaxRate + 0.05) * 1.5 + (IFNULL(d.fare, 0) * 1.25)
            END AS calculatedNetworkGuaranteedPrice
        ") // 计算日本供货价
        ->having("calculatedNetworkGuaranteedPrice >= {$PriceMin} AND calculatedNetworkGuaranteedPrice <= {$PriceMax}")
        ->where([['g.id','>=',95],['g.id','<=',103]])
        ->limit(10)
        ->select();
        // dump($list);
        // die;
        foreach($list as $vo){
          echo $vo['id'] . '==' . $vo['calculatedNetworkGuaranteedPrice'] . '<br>';
        }
解释:

from clipboard

需要用到关联表中的fare,参与计算,

但是如果goods中某条信息没有关联表,则该条信息也不显示了,

需求是,没有关联信息,可以默认fare为0,该条信息还正常显示,

则可以做在使用fare字段的时候用IFNULL(d.fare, 0)判断一下

版权声明:本站原创文章,允许自由转载。

相关推荐
Non-static method think\Config::get() should not be called statically
ThinkPHP5.1 | 2018-12-29 11559
原来是这样use think\Config; 改成这样use think\facade\Config; 下面是官方手册的解释 配置获取 要使用Config类,首先需要在你的类文件中引入 use think\facade\Config; 或者(因为系统做了类库别名,其实就是调用think\facade\Config) u...
thinkPHP5 order多条件排序
ThinkPHP5.1 | 2017-10-24 11427
总结如下: //单一条件排序 $user = $this->where(['parentId'=>0)->field('userId,userName,userSort,isShow')->order('userSort', 'asc')->select(); //多个条件排序,可以多加一个order...
评论:0条
评论加载中...
发表评论