6

我有一个 bookings.php 页面,其中有一个 jqgrid,显示所有在线预订。当您双击一行时,这将打开一个 jq 对话框,其中显示有关该预订的所有详细信息。此外,当您双击时,我定义了一个变量,它是我要传递给 php 脚本的预订参考:

var brData = rowData['bookref'];

我通过 ajax 发送这个变量:

function getGridRow(brData) {

   $.ajax({

    // Request sent from control panel, so send to cp.request.php (which is the handler)
    url: 'scripts/php/bootstrp/all.request.php',
    type: 'GET',

    // Build data array - look at the '$_REQUEST' parameters in the 'insert' function
    data: {


        //ft: "getDGRow",
        rowdata: 'fnme=getDGRow&row_data='+brData,
        data: brData,

        // Either pass a row id as the 'id' OR a where clause as the 'condition' never both
        id: null,
        condition: null
    },
    dataType: 'text',
    timeout: 20000,
    error: function(){
        alert("It failed");
        $('#cp-div-error').html('');
        $('#cp-div-error').append('<p>There was an error inserting the data, please try again later.</p>');
        $('#cp-div-error').dialog('open');
    },
    success: function(response){

        // Refresh page

       // response = brData;
       // alert(response);

    }
});


}

这是 all.inc.php 的 switch 案例:

case 'getDGRow':
//header('Content-type: text/xml');
DatagridController::getGridRow($_REQUEST['rowdata']);
break;

这是我将 jquery 变量发送到的 PHP 函数,以在我的 PHP 代码中使用:

public static function getGridRow($rowdata) {

    $rowdata = $_GET['data'];
    echo $rowdata;

    $pdo = new SQL();
    $dbh = $pdo->connect(Database::$serverIP, Database::$serverPort, Database::$dbName, Database::$user, Database::$pass);

    try {

        $query = ("SELECT * FROM tblbookings WHERE bookref = '$rowdata'");

        $stmt = $dbh->prepare($query);

        $stmt->execute();

        $row = $stmt->fetch(PDO::FETCH_BOTH);

        BookingDocket::set_id($row['id']);
        BookingDocket::set_bookref($row['bookref']);
        BookingDocket::set_bookdate($row['bookingdate']);
        BookingDocket::set_returndate($row['returndate']);
        BookingDocket::set_journeytype($row['journeytype']);
        BookingDocket::set_passtel($row['passengertel']);
        BookingDocket::set_returndate($row['returndate']);



        $stmt->closeCursor();

    }

    catch (PDOException $pe) {
        die("Error: " .$pe->getMessage(). " Query: ".$stmt->queryString);
    }

    $dbh = null;

}


}

我已经把 echo $rowdata; 在 PHP 函数中查看是否正在传递变量,因为我可以在 firebug 控制台中看到“BR12345”。问题是这个查询:

 $query = ("SELECT * FROM tblbookings WHERE bookref = '$rowdata'");

没有获取任何结果。如果我要说:

 $query = ("SELECT * FROM tblbookings WHERE bookref = 'BR12345'");

它确实获取了我需要的结果,所以我不明白为什么当变量 brData 被传递给 $rowdata 时这个查询不起作用

有什么建议么?

4

5 回答 5

2

想知道为什么您的代码中有一个准备好的语句,但实际上没有正确使用它。

$stmt = $dbh->prepare("SELECT * FROM tblbookings WHERE bookref = :data");
$stmt->execute(array(
    ':date' => trim($rowdata),
));

我已经添加trim()以确保它周围没有空格或换行符可能会搞砸。

更新

现在是调试时间:

public static function getGridRow($rowdata) {

    $rowdata = $_GET['data'];
    echo $rowdata;

添加以下行:

    echo "=====DEBUG====== ";
    var_dump($rowdata); 
    echo " =====DEBUG====== ";
    exit;

这将写入值并立即停止您的脚本,以便您可以详细检查其值。

于 2012-06-08T08:47:05.983 回答
1

使用函数

HtmlSpecialChar() 
Trim()

然后显示 $rowdata 变量,如果字符串格式正确,则

试试这个

 $query = ("SELECT * FROM tblbookings WHERE bookref = '$rowdata'");

或者

 $query = ("SELECT * FROM tblbookings WHERE bookref = '".$rowdata."'");

PHP 可以看到没有 -> ' 的变量

于 2012-06-08T08:38:07.113 回答
0

我的答案是错误的,我没有删除它,所以没有人发布这个错误的答案
证明我错了:http ://codepad.org/fvHM81Uh

尝试

$query = ("SELECT * FROM tblbookings WHERE bookref = '" . $rowdata . "'");

在 PHP 中,字符串中的 vars 是这样处理的:

$variable = "Hello";
echo "$variable"; //=> Hello
echo '$variable'; //=> $variable

但:

 echo "'$variable'"; //=> 'Hello'
于 2012-06-08T08:41:32.023 回答
0

不确定 $rowdata 是否是一个数组,但我假设它不是。在这种情况下,您是否尝试过:

$query = "SELECT * FROM tblbookings WHERE bookref = " . $rowdata;
于 2012-06-08T15:59:25.270 回答
0

试着先解决你的问题。你说你对firebug没有问题,试着把console.dir()响应放在这里验证。

同时执行以下操作:

然后$_REQUESTprint_r(). 你的变量在那里吗?如果是这样,请执行var_dump($_REQUEST['rowdata'])并检查。

public static function getGridRow($rowdata)看到你覆盖$rowdata看到回声。最后,如果您现在一切顺利,请正确准备您的查询

于 2012-06-08T17:18:58.947 回答