[英]how to paginate the retrieved data from mysql database by using php
我在我的网站上有一个搜索页面,用户可以在其中搜索数据库中的所有数据。我在数据库中有一个名为property的表,可以从中提取所有搜索到的数据。 现在我想将分页添加到我的结果页面,并且只想在首页上显示8条记录。 我的网站在wordpress中,根据搜索检索数据的代码如下:
<?php
if(isset($_REQUEST['submit']))
{
$search = $_POST['cs'];
$field_array = array('ID', 'ManagementCompanyID', 'MarketingName', 'PropertyURL', 'Address', 'City', 'State', 'PostalCode', 'StructureType', 'UnitCount', 'YearBuilt', 'LeaseLength', 'Parking', 'ShortDescription');
foreach($field_array as $value)
{
$query = "SELECT * FROM `wp_property` WHERE `$value` LIKE '%$search%' ";
$result = mysql_query($query);
while($row = mysql_fetch_assoc($result))
{
echo "<pre>";
print_r($row);
echo "<pre>";
}
}
}
?>
$ field_array的元素是wp_property表的列。 任何帮助将不胜感激..在此先感谢
尝试这个:
<?php
if(isset($_POST['submit'])) { // DO NOT USE $_REQUEST unless You are sure You need this... Use $_GET or $_POST accordingly...
$search = mysql_real_escape_string($_POST['cs']); // ALWAYS sanitize user input
$field_array = array('ID', 'ManagementCompanyID', 'MarketingName', 'PropertyURL', 'Address', 'City', 'State', 'PostalCode', 'StructureType', 'UnitCount', 'YearBuilt', 'LeaseLength', 'Parking', 'ShortDescription');
// Pagination
$limit = 15; // change that constant if You want or let it be a value from form...
$offset = isset($_POST['page']) ? mysql_real_escape_string($_POST['page']) : 0;
$offset = $offset * $limit;
$where = ' WHERE (';
$cnt = count($field_array);
$i = 0;
foreach($field_array as $value) {
$where .= " {$value} LIKE '%{$search}%'";
if($i < $cnt) $where .= ' OR ';
$i++;
}
$where .= ')';
$query = "SELECT * FROM `wp_property` {$where} LIMIT {$offset}, {$limit}";
$result = mysql_query($query);
while($row = mysql_fetch_assoc($result)) {
echo "<pre>";
print_r($row);
echo "<pre>";
}
}
现在,通过改变$_POST['page']
值为1
, 2
, 3
...您可以通过数据分页...让分页的您的HTML部分,但是你想(链接,按钮等)。
我建议不要使用mysql_*
函数,至少要使用mysqli
或PDO
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.