保留$ _GET值,除了两个指定的值

时间:2015-01-02 23:45:50

标签: php mysql

我有一个用于搜索数据库的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

2 个答案:

答案 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);