[英]Replace NULL Value in MySQL
使用這個時如何查找和替換空行.....
$Qemaster="select * from emaster where `branch`='$bid' and `department`='$did' and `status`!='L'";
$Remaster=mysql_query($Qemaster);
while($Rowemaster=mysql_fetch_array($Remaster)){
$empcode=$Rowemaster[id];
$name=$Rowemaster[name];
$Tleave=0;
echo "<tr>";
echo "<td rowspan='2'>".$name."</td>";
echo "<td>Leave</td>";
$Qlp="select * from lpsummary where ((`month` IN(04,05,06,07,08,09,10,11,12) and `year`='$year') or (`month` IN (01,02,03) and `year`='$Nyear')) and `empcode`='$empcode'";
$Rlp=mysql_query($Qlp);
$RRlp=mysql_num_rows($Rlp);
while($Rowlp=mysql_fetch_array($Rlp)){
$leave=$Rowlp['leave'];
$Tleave=$Tleave+$leave;
if($leave==NULL){
$Eleave='-';
}
else{
$Eleave=$leave;
}
echo "<td>".$Eleave."</td>";
}
echo "<td><font color='red'>".$Tleave."</font></td>";
echo "<td><font color='green'>".substr(($Tleave/$RRlp),0,4)."</font></td>";
echo "<tr><td>Percentage</td>";
}
如果有一個空行......我想把它替換為 - 而不是echo“”。$ Eleave。“”;
實際上你可以直接通過查詢來做到這一點,所以你的PHP代碼中沒有任何IF-ELSE
條件。使用COALESCE()
,例如
另外,養成指定列名的習慣,而不是使用*
。
SELECT colnames,..., COALESCE(`leave`, '-') `Leave`
FROM lpsummary
WHERE .....
更新1
SELECT COALESCE(l.leave, '-') AS `LEAVE`
FROM lpsummary l
WHERE (
(month IN(04,05,06,07,08,09,10,11,12) and year='$year') or
(month IN (01,02,03) and year='$Nyear')
) and empcode='$empcode'
作為一個旁注,查詢是脆弱的SQL Injection
,如果變量的值(一個或多個 )從外面走了進來。 請查看下面的文章,了解如何防止它。 通過使用PreparedStatements
您可以擺脫使用值周圍的單引號。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.