我希望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;发布于 2019-10-23 18:28:06
在SQL中,该数字将在以下行中转换为字符串:
WHERE ic.contentid ='". $idnr ."'"如果在数字两边添加单引号,则该数字将被SQL引擎解释为字符串。您应该删除单引号,并告诉SQL引擎您正在为该变量分配一个数字:
WHERE ic.contentid = ". $idnr https://stackoverflow.com/questions/58520749
复制相似问题