加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

Perl中的Mysql查询参数问题

发布时间:2020-12-15 23:26:21 所属栏目:大数据 来源:网络整理
导读:我的代码有点问题,如果我手动输入值,查询工作正常.但如果我使用我的变量则失败.代码如下所示 my $get_meter_id = $dbh-prepare("SELECT * from t_readings where meter_serial = '21001652' AND ...");$get_meter_id-execute() or die "Couldn't execute sta
我的代码有点问题,如果我手动输入值,查询工作正常.但如果我使用我的变量则失败.代码如下所示

my $get_meter_id = $dbh->prepare("SELECT * from t_readings where meter_serial = '21001652' AND ...");
$get_meter_id->execute() or die "Couldn't execute statement: ".$get_meter_id->errstr;
my $meter_reg_id = $get_meter_id->fetchrow_array();

上面的一个工作

where meter_serial = 21001652 AND ...")

上面的一个工作.

where meter_serial = '".$variable."' AND ...")

以上不起作用

where meter_serial = ".$variable." AND ...")

以上不起作用

非常感谢.

解决方法

使用占位符.不要乱用字符串连接.

my $get_meter_id = $dbh->prepare("SELECT * from t_readings where meter_serial=? AND ...");
my $foo = 21001652;
$get_meter_id->execute($foo) or die "Couldn't execute statement: ".$get_meter_id->errstr;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读