亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

讀取具有 31 個不同列的 mysql 表

讀取具有 31 個不同列的 mysql 表

PHP
慕田峪4524236 2023-10-15 16:37:08
我需要閱讀一張代表每月登記的表格。有點像year, month, name, d1...d31 <--days of the month我使用這個函數來獲取當月的全球小時數function calchour($db, $table, $year, $month){    $daysinmonth =cal_days_in_month(CAL_GREGORIAN, $month, $year);//Nbr of days in month    $tt_hour = '0';    $result = mysqli_query($db,"SELECT * FROM $table WHERE anno = '$year' AND month = '$month'") or merror($msg = mysqli_error($db));      while ($row = mysqli_fetch_array($result))    {        $volhr = '0';        for ($i = '1'; $i <= $daysinmonth; $i++) {            $day = 'd'.$i;            $hour = $row[$day];            if (($hour != '')) { $volhr = $volhr + $hour; }        }        $tt_hour = $tt_hour + $volhr;    }return $tt_hour;    }有沒有更好的方法來獲取當月的全球小時數?
查看完整描述

1 回答

?
繁星coding

TA貢獻1797條經驗 獲得超4個贊

我將它們添加到sql中:


SELECT SUM(

    coalesce(d1,0)+coalesce(d2,0)+coalesce(d3,0)+coalesce(d4,0)+coalesce(d5,0)+coalesce(d6,0)+coalesce(d7,0)+coalesce(d8,0)+coalesce(d9,0)+coalesce(d10,0)+coalesce(d11,0)+coalesce(d12,0)+coalesce(d13,0)+coalesce(d14,0)+coalesce(d15,0)+coalesce(d16,0)+coalesce(d17,0)+coalesce(d18,0)+coalesce(d19,0)+coalesce(d20,0)+coalesce(d21,0)+coalesce(d22,0)+coalesce(d23,0)+coalesce(d24,0)+coalesce(d25,0)+coalesce(d26,0)+coalesce(d27,0)+coalesce(d28,0)+coalesce(d29,0)+coalesce(d30,0)+coalesce(d31,0))

) total_hours ...

不過,最好重新組織數據庫,為每個值分配一個單獨的行。任何時候你有名為column1、column2等的列,這都是糟糕的數據庫設計的標志。所以像這樣:


 create table volhours (

     date date not null primary key,

     volhours int

 );

并選擇一系列日期的總小時數:


 select coalesce(sum(volhours),0) total_hours from volhours where date between '2020-01-01' and '2020-01-31';

當然,您應該使用占位符。


查看完整回答
反對 回復 2023-10-15
  • 1 回答
  • 0 關注
  • 134 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號