doucaigai7176 2014-05-22 19:34
浏览 36

函数与字符串参数

I have function

function count_where($param, $value)
{
    $result=mysql_query("SELECT COUNT(*) AS TOTAL FROM vote WHERE '$param'='$value'");
    $data=mysql_fetch_assoc($result);
    return $data['TOTAL'];
}

and try to call it

count_where('picture','black circle')

where picture has varchar type (in MySQL). It doesn't work.

This

$result=mysql_query("SELECT COUNT(*) AS TOTAL FROM vote WHERE picture='black circle'");
 $data=mysql_fetch_assoc($result);
 echo $data['TOTAL'];

work;

  • 写回答

3条回答 默认 最新

  • duanlv1366 2014-05-22 19:37
    关注

    if you want to encapsulate the column name, use backticks ` instead of apostrophes '

    But be careful, watch out for sql injection. Before running the query you can better do:

    $param = mysql_real_escape_string($param);
    $value = mysql_real_escape_string($value);
    
    评论

报告相同问题?

悬赏问题

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