Php 如何将字符串转换为数字,以便在select语句中使用?
我希望where子句有一个数字id,但我希望它带有一个变量,这样我就可以很容易地选择它 我制作了一个字符串,将数字放在那里,并将其粘贴到select语句中,但它不起作用,因为它似乎没有将其作为数字读取Php 如何将字符串转换为数字,以便在select语句中使用?,php,sql,string,Php,Sql,String,我希望where子句有一个数字id,但我希望它带有一个变量,这样我就可以很容易地选择它 我制作了一个字符串,将数字放在那里,并将其粘贴到select语句中,但它不起作用,因为它似乎没有将其作为数字读取 $sql = "SELECT ic.metatitle, im.name, ic.metadesc, ic.metakeywords FROM isacontent_content ic INNER JOIN isacontent_module_anchorimage im ON im.cont
$sql = "SELECT ic.metatitle, im.name, ic.metadesc, ic.metakeywords FROM
isacontent_content ic
INNER JOIN isacontent_module_anchorimage im ON im.contentid =
ic.contentid
WHERE ic.contentid ='". $idnr ."'";
$result = $conn->query($sql);
if(is_array($result)){
foreach ($result as $resItem){
$metaData[] = $resItem->fetch_assoc();
}
}
else{
$metaData[] = $result->fetch_assoc();
}
$defaultImage = "isadesign-default-anchor.png";
$title = $metaData[0]["metatitle"];
$image =$metaData[0]["name"];
$desc = $metaData[0]["metadesc"];
$keys =$metaData[0]["metakeywords"];
$img_str = "/anchor/images/";
$site_str = "https://";
$contentid =$metaData[0]["contentid"];
$_idnr = "12245";
$idnr = (int)$_idnr;
此行中的数字在SQL中转换为字符串:
WHERE ic.contentid ='". $idnr ."'"
如果在数字周围添加单引号,SQL引擎会将数字解释为字符串。您应该删除单引号,并告诉SQL引擎您正在为该变量分配一个数字:
WHERE ic.contentid = ". $idnr
有关详细说明,请查看php_errors.log文件。代码中可能有一些语法错误。