gpt4 book ai didi

php - 数据库查询表选择从第二行开始而不是第一行

转载 作者:太空宇宙 更新时间:2023-11-03 10:38:05 24 4
gpt4 key购买 nike

我基本上使用 html、php、Smarty。

当我循环我的结果以显示数据库表行时,它会忽略我的数据库表的第一行。

因此,如果我有一个包含 3 行的表(product_id = 1、product_id = 2、product_id = 3),它只会显示 product_id“2”和“3”。

我希望能够显示第一行 - (product_id = 1)

.PHP

<?php

$new = ['product_id','product_category','product_price','product_quantity','product_about','product_color'];

//Database connection
$db = mysqli_connect('xxx','xxx','xxx','xxx')
or die('Error connecting to MySQL server.');

//access Smarty template engine
require_once('Smarty-3.1.30/libs/Smarty.class.php');

$smarty = new Smarty();
$smarty->template_dir = 'views';
$smarty->compile_dir = 'tmp';


//query product page
$query = "SELECT * FROM cs_shop";
mysqli_query($db, $query) or die('Error querying database.');

$result = mysqli_query($db, $query);
$row = mysqli_fetch_array($result);


//query an array of products
$rows = array();

//loop start
while ($row = mysqli_fetch_array($result)) {
$rows[] = array(
'product_id' => $row['product_id'],
'product_category' => $row['product_category'],
'product_price' => $row['product_price'],
'product_quantity' => $row['product_quantity'],
'product_about' => $row['product_about'],
'product_color' => $row['product_color']
);
}

//db collect data
$smarty->assign('row', $rows);
//template
$smarty->display('index.tpl');

mysqli_close($db);

?>

.TPL

<div class="test divider">

<ul>
{foreach from=$row item="item"}
<li>{$item['product_id']}</li>
{/foreach}
</ul>

</div>

结果

2
3

现在如何显示缺少的 id.. 我对此很陌生,因此非常感谢任何提示或帮助。提前致谢。

预期结果

1
2
3

最佳答案

在查询 $result = mysqli_query($db, $query); 之后删除以下行:

$row = mysqli_fetch_array($result); // REMOVE ME

它会检索第一个结果,然后在它进入您的 while 循环并获取下一个结果之前您无需对其进行任何操作。

关于php - 数据库查询表选择从第二行开始而不是第一行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43982536/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com