[英]How to display SQL query results in one line?
我想出去试图让它发挥作用,我在这里,我有3张桌子。 我认为向你展示桌子是“tblhosting”,“tblhostingconfigoptions”和“tblcustomfieldsvalues”会更好。这可以在SQLFiddle设置中看到: http ://sqlfiddle.com/#!9 / 6c153 / 1
我想要完成的是将它放在一行,见图:
下面是我的SQL查询:
SELECT DISTINCT
t1.domainstatus,
t1.server,
t1.dedicatedip,
t1.packageid,
t1.regdate,
t1.nextduedate,
t2.value,
t2.fieldid,
t3.configid,
t3.qty
FROM tblhosting t1
INNER JOIN tblcustomfieldsvalues t2
ON t2.relid = t1.id
INNER JOIN tblhostingconfigoptions t3
ON t3.relid = t1.id
WHERE t3.configid IN (126,127,128) AND t2.fieldid IN
(83,84,85,86,87,88,90,91,92,93,208) ORDER by t1.id -- I use to have GROUP by t1.id and get 1 line for the 126 but then 127 128 will not be produced.
我将<td>
隔离到问题所在,它都在这个PHP代码中:
$sql = mysql_query($queryText);
while($row = mysql_fetch_array($sql)) {
$qty = $row['qty'];
$configid = $row['configid'];
echo '<td id="sid">' . $row['value'] . '</td>';
echo '<td id="smip">' . $dedicatedIP . '</td>';
echo '<td id="10g">'; if ($configid == 126) { echo '4' } echo'</td>'; // the qty matching 126 should display there
echo '<td id="40g">'; if ($configid == 127) { echo '0'} echo'</td>'; // the qty matching 127 should display there
echo '<td id="100g">'; if ($configid == 128) { echo '0' } echo'</td>'; // the qty matching 128 should display there
....上面的想法是使$configid
匹配126或127或128,并相应地输出行qty
为4 0 0并且不输出3次“ded13526”并且输出4然后下一行0然后下一行0。
希望它有足够的解释,我不想发布整个代码混淆,很明显IN
语句有80到93然后208,这个确切的条目只有93 ..
我只是不知道出了什么问题..
尝试这个:
SELECT DISTINCT
t1.domainstatus,
t1.server,
t1.dedicatedip,
t1.packageid,
t1.regdate,
t1.nextduedate,
t2.value,
t2.fieldid,
t3.configid,
t3.qty
FROM tblhosting t1
INNER JOIN tblcustomfieldsvalues t2
ON t2.relid = t1.id
INNER JOIN tblhostingconfigoptions t3
ON t3.relid = t1.id
WHERE t3.configid IN (126,127,128) AND t2.fieldid IN
(83,84,85,86,87,88,90,91,92,93,208) GROUP BY t2.fieldid
如果我正确理解您的问题,可以解决以下问题:
SELECT DISTINCT
t1.domainstatus,
t1.server,
t1.dedicatedip,
t1.packageid,
t1.regdate,
t1.nextduedate,
t2.value,
t2.fieldid,
(SELECT qty FROM tblhostingconfigoptions WHERE relid = t1.id AND configid = 126) AS qty126,
(SELECT qty FROM tblhostingconfigoptions WHERE relid = t1.id AND configid = 127) AS qty127,
(SELECT qty FROM tblhostingconfigoptions WHERE relid = t1.id AND configid = 128) AS qty128
FROM tblhosting t1
JOIN tblcustomfieldsvalues t2 ON t2.relid = t1.id
WHERE t2.fieldid IN (83,84,85,86,87,88,90,91,92,93,208)
while($row = mysql_fetch_array($sql)) {
...
echo '<td id="sid">' . $row['value'] . '</td>';
echo '<td id="smip">' . $row['dedicatedip'] . '</td>';
echo '<td id="10g">' . $row['qty126'] . '</td>';
echo '<td id="40g">' . $row['qty127'] . '</td>';
echo '<td id="100g">' . $row['qty128'] . '</td>';
...
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.