Php 如何将字符串转换为数字,以便在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

我希望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.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文件。代码中可能有一些语法错误。