doufang3001 2015-02-04 15:35
浏览 57

在MySQL中的select语句中阻止变量计算

I'm trying to build a dynamic query based upon selections passed to a script. Example:

$qry = "SELECT * FROM machinekaart 
INNER JOIN afleveradressen ON afleveradressen.raaid = mkrraaid 
INNER JOIN kontaktpersonen ON kontaktpersonen.rkpraaid = mkrraaid   
WHERE mkrrid != '' " ;

if($_SESSION['oud'])
    $qry .= "  AND mkrvo < " . $cur_jaar_maand;

Field mkrvo is a text field, and can contain yyyy-mm besides other values.

e.g. when the varable $cur_maand_jaar contains '2015-01' the selection will be everything lower than 2014

How can I stop this from happening and selecting everything lower than '2015-01' ??

  • 写回答

2条回答 默认 最新

  • dsa456369 2015-02-04 15:45
    关注

    I would suggest quoting that variable, so the values are taken literally:

    if($_SESSION['oud'])
        $qry .= "  AND mkrvo < '" . $cur_jaar_maand . "'";
    

    Better than that, please use PDO so you can use bindings, it's safer and best optimized.

    Eg.

    if($_SESSION['oud'])
        $qry .= "  AND mkrvo < ?";
    
    // build your PDO Connection $myPdoConnection ...
    
    $pdoStatement = $myPdoConnection->prepare($qry);
    
    $pdoStatement->execute(array($cur_jaar_maand));
    
    评论

报告相同问题?

悬赏问题

  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测