首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如果其他值大于0,则Php If语句采用最小数字

如果其他值大于0,则Php If语句采用最小数字
EN

Stack Overflow用户
提问于 2018-08-28 07:48:38
回答 1查看 23关注 0票数 0

底部是我的代码。我的数据库有8列SKU,价格1,价格2,价格3,最低价格,数量1,数量2,数量3

我想在我的脚本中添加一些if语句来检查三个参数。如果是qty>0

目前,我正在从价格1-3导出最小的数字,但它不检查是否存在任何大于0的数量。

这是我的代码:

代码语言:javascript
复制
<?php 
if (isset($_SERVER['REMOTE_ADDR'])) {
    die(':)');
}

echo "Cron is running";

$hostname   = 'localhost';
$username   = 'user';
$password   = 'pass';
$myDatabase = 'database';
/**
 * Defines the name of the table where data is to be inserted
 */
$table = 'mytable';

try {
    $conn = new PDO('mysql:host=localhost;dbname='.$myDatabase, $username, $password);
    $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);    

    $stmt = $conn->prepare("SELECT mytable.SKU AS SKU,  LEAST(price, price2, price3) AS 'Lowest2'
    FROM mytable
    ");


    $stmt->execute();

    $filelocation = 'assets/exports/';
    $filename     = 'export-'.date('Y-m-d H.i.s').'.csv';
    $file_export  =  $filelocation . $filename;

    $data = fopen($file_export, 'w');

    $csv_fields = array();

    $csv_fields[] = 'SKU';
    $csv_fields[] = 'Lowest2';


    fputcsv($data, $csv_fields);

    while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
        fputcsv($data, $row);
    }

} catch(PDOException $e) {
    echo 'ERROR: ' . $e->getMessage();
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-28 07:52:22

您可以将查询更改为类似以下内容:

代码语言:javascript
复制
SELECT mytable.SKU AS SKU, 
     LEAST(CASE WHEN qty  > 0 THEN price  ELSE 99999999999 END, 
           CASE WHEN qty2 > 0 THEN price2 ELSE 99999999999 END, 
           CASE WHEN qty3 > 0 THEN price3 ELSE 99999999999 END) AS 'Lowest2'
FROM mytable

我假设所有的价格都在99999999999以下...

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52048302

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档