dqrm8199 2012-02-25 17:07
浏览 6
已采纳

用于MySQL SELECT的PHP函数[重复]

Possible Duplicate:
Warning: mysql_fetch_array() expects parameter 1 to be resource, boolean given in

    function arr($string)
    {
        $tank5 = "SELECT url FROM `db`.`tank` WHERE url LIKE {$string}";
        $result5 = mysql_query($tank5);
            if (!$result5) {
    die('Invalid query: ' . mysql_error());
}

        $parts2 = array();
        while ($p = mysql_fetch_array($result5)) {
            $parts2[] = $p['url'];
        }

        // return the array created.
        return $parts2; 
    }

    $array5 = arr('lol.com');       
    print_r($array5);

Why don't the above code work. The error I'm getting is
Warning: mysql_fetch_array() expects parameter 1 to be resource, boolean given in /usr/local/...
so I guess it's not database connection problem. Any idea?

  • 写回答

2条回答 默认 最新

  • doujiaoben28596 2012-02-25 17:09
    关注

    Most likely, you're using a LIKE clause but not passing wildcards with $string. Therefore, it would only find exact matches.

    Instead surround $string with % and single-quotes, since you did not quote the input value (assuming the function's input parameter doesn't already have quotes, which seems unlikely).

    $tank5 = "SELECT url FROM `db`.`tank` WHERE url LIKE '%$string%'";
    

    We assume that prior to calling this function, you have already escaped $string against SQL injection like:

    $string = 'lol.com';
    $string = mysql_real_escape_string($string);
    $arr = arr($string);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥30 python代码,帮调试,帮帮忙吧
  • ¥15 #MATLAB仿真#车辆换道路径规划