Современные столы с грушей php
Я строю динамическую таблицу, используя php, pear HTML_Table и sql. Мой первый запрос извлекает информацию для заголовков таблицы, а затем Pear использует ее для создания заголовков. Следующий запрос извлекает информацию из нескольких таблиц, чтобы вернуть правильные наборы данных. Затем мне нужно привязать эти наборы данных к заголовкам и отобразить результаты в каждом соответствующем столбце. Я могу отобразить все данные, но не правильно. Столбец 0 начинается со строки 1 и отображает текущие 4 тестовых элемента, столбец 1 начинается со строки 5 и отображает текущие 2 тестовых элемента, затем столбец 2 начинается с 7... Как я могу вернуть счетчик столбцов в 0 после в предыдущем столбце заканчиваются совпадающие данные? Другая часть этой проблемы заключается в том, что мне также нужно применить rowSpans к вставленным данным, так как это проект планирования. Я занимаюсь этим уже неделю и не смог найти ни одного уместного примера или предложения. Чего мне не хватает, так как я не думаю, что это должно быть такой сложной задачей? Код ниже.
<?php
session_start();
include_once("../php/functions.php");
include_once("HTML/TABLE.PHP");
$assetHead = headers('Assets', $_SESSION['deptID']);
$captionHeading = $_SESSION['dept'];
$conn = connect();
$attrs = array( 'id' => 'main',
'width' => '100%',
'Border' => '1');
$table = new HTML_Table($attrs);
$table->setAutoGrow(true);
$table->setAutoFill('n/a');
$sql_assets = "select AssetName, AssetID
from Assets
where Assets.DepartmentID = $_SESSION[deptID]";
$stmt1 = sqlsrv_query($conn, $sql_assets);
if ($stmt1)
{
$rows = sqlsrv_has_rows($stmt1);
if ($rows === true)
{
while( $row = sqlsrv_fetch_array( $stmt1, SQLSRV_FETCH_ASSOC) )
{
$assetName [] = $row['AssetName'];
$assetID [] = $row['AssetID'];
}
}
}
else
{
die( print_r(sqlsrv_errors(), true));
}
$i = 0;
foreach($assetName as $val)
{
$table->setHeaderContents(0, $i++, $val);
unset($val);
}
sqlsrv_close($conn);
$conn = connect();
$tsql = "select + 'Job#' + CAST (JobNum AS VARCHAR(10))+ ' ' + Description AS newField, datediff(MI,StartTime, EndTime) / 15 as 'RowSpan', AssetName, AssetID
from Calendar_View, Departments, Status, Assets
where Departments.DepartmentName = '$captionHeading' and Calendar_View.Department = Departments.DepartmentID and AssetStatus = Status.StatusID and
Calendar_View.Asset = Assets.AssetID
order by AssetID asc";
$rowcounter = 1;
$stmt = sqlsrv_query($conn, $tsql);
if ($stmt)
{
while( $row = sqlsrv_fetch_array( $stmt, SQLSRV_FETCH_ASSOC) )
{
for ($i = 0; $i < count($assetID);$i++)
if ($row['AssetID'] == $assetID[$i])
$table->setCellContents($rowcounter++,$i,$row['newField']);
}
}
else
{
die( print_r(sqlsrv_errors(), true));
}
sqlsrv_close($conn);
echo $table->toHTML();
?>
</body>
</html>
$ headerCounter = 0; $ stmt = sqlsrv_query ($ conn, $ tsql); if ($ stmt) {
$ row = sqlsrv_has_rows($stmt);
if ($row === true) {
$ cellCounter = 1; $ cellPosition = 0; $ rowCounter = 1; echo "Положение заголовка вне цикла: $ headerCounter
";
while( $row = sqlsrv_fetch_array( $stmt, SQLSRV_FETCH_ASSOC) )
{
if ($row['AssetID'] == $assetID[$headerCounter])
{
echo "<br>begining of if statement<br>";
echo "Header (beginning of loop) = " . $assetName[$headerCounter] . "<br>" ;
echo "Header Position (beginning of loop) = " . $headerCounter . "<br>";
echo "Row position = " . $rowCounter . "<br>" ;
echo "Cell position = " . $cellPosition . "<br>";
echo "<pre>";
var_dump($row);
echo "</pre>";
/*foreach ($row as $result)
{
echo "<pre>";
var_dump($result);
echo "</pre>";
}*/
$table->setCellContents($rowCounter,$cellPosition,$row['newField']);
//echo "$headerCounter";
//echo "<br>";
echo "Header Name (end of loop) = " . $assetName[$headerCounter] . "<br>" ;
echo "Header Position (end of loop) = " . $headerCounter . "<br>";
echo "Row position = " . $rowCounter . "<br>" ;
echo "Cell position = " . $cellPosition . "<br>";
//$cellPosition++;
$rowCounter++;
echo "end of if statment<br><br>";
}
else
{
echo "<br>header before increase $headerCounter";
echo "<br>header name outside of loop, before increment $assetName[$headerCounter]";
$cellPosition++;
$rowCounter = 1;
$headerCounter++;
$table->setCellContents($rowCounter,$cellPosition,$row['newField']);
echo "<br>header name outside of loop, after increment $assetName[$headerCounter]";
echo "<br>header increased by 1, now: $headerCounter";
}
}//$headerCounter++;
//$table->setCellContents($rowCounter,$cellPosition,$row['newField']);
}
1 ответ
Хорошо, проблема была в том, что я не увеличивал переменную rowcounter после того, как вышел из начального цикла. Следующая строка:
$cellPosition++;
$rowCounter = 1;
$headerCounter++;
$table->setCellContents($rowCounter,$cellPosition,$row['newField']);
Должно было:
$cellPosition++;
$rowCounter = 1;
$headerCounter++;
$table->setCellContents($rowCounter++,$cellPosition,$row['newField']);
Извините за плохое форматирование оригинального поста. Я не уверен, что пошло не так.