我有一个用于搜索数据库的HTML表单,表单方法是GET:
<form method="get" action="">
然后我的SQL查询使用$_GET
值
我运行SQL,然后有这个函数 - (http://pastebin.com/J3RL3MxC) - 我在查询下面运行
所以总的来说,它看起来像:
$sql="SELECT * FROM customer ORDER BY company";
$i=0;
$array = ShowRecords($sql, "customer");
foreach($array["results"] as $ret) {
}
我在foreach循环中回显我的结果
这工作正常,但是当浏览函数创建的页面时,我放松了$_GET
值,所以我也松了我搜索的内容
如何保留$_GET
值,但请注意,$_GET["pagenum"]
需要删除/更改,以便页面更改
我已添加此代码:
$query_string = '?';
foreach($_GET as $q => $k) {
if($q == 'id' or $q == 'pagenum') {
//
} else {
if($q != '') {
$query_string = '&'.$q.'='.$k;
}
}
}
在我的函数顶部尝试做所需的事情($ _GET [&#34; id&#34;]也需要删除)但是它没有保留值
除了指定的值之外,保留所有$ _GET值的最佳方法是什么?
P.S:我知道我应该使用PDO,一旦我将此问题排序,我将立即更改我的代码以使用PDO
答案 0 :(得分:0)
$id = isset($_GET["id"]) ? $_GET["id"] : NULL;
$pagenum = isset($_GET["pagenum"]) ? $_GET["pagenum"] : NULL;
if($id) {
}
if($pagenum) {
}
答案 1 :(得分:0)
使用http_build_query构建查询字符串,而不是手动执行: http://php.net/manual/en/function.http-build-query.php
我只是将所有请求变量存储在一个数组中并根据需要进行更新。当准备输出任何链接时,只需使用http_build_query生成查询字符串
$request = $_GET;
unset($request['id']);
$request['pagenum'] = 2;
//etc
$query_string = '?' . http_build_query($request);