我正在重新审视我的旧时尚mysql相关代码,并将它们转换为准备好的声明表。
以下查询工作正常。
$sorgu = "SELECT * FROM tb_yazilar WHERE kolon_etiketler REGEXP '[[:<:]]".$adres_get_elemanlari[2]."[[:>:]]' ORDER BY kolon_sno DESC";
$sorgum = "SELECT kolon_yazar, kolon_baslik, kolon_ytarihi FROM tb_yazilar WHERE kolon_etiketler REGEXP CONCAT('[[:<:]]"', ?, '"[[:>:]]') AND kolon_statu = ? ORDER by kolon_onaytarihi DESC";
if ($beyan = $db_baglanti->prepare($sorgum))
{
/* bind parameters */
$beyan -> bind_param("ss", $bindparametre1, $bindparametre2);
/* assign values to bind parameters */
$bindparametre1 = tire_bosluk_olsun($_GET['rd_ozne']);
$bindparametre2 = 'onay';
/* execute statement */
$beyan->execute();
/* bind result variables */
$beyan->bind_result($yazar, $baslik, $ytarihi);
echo "\t".'<div class="sol-icerik-kapsar">'."\r\n";
echo "\t\t".'<h1>'.$_GET['rd_ozne'].'İLE ETİKETLENDİRİLMİŞ YAZI(LAR)</h1>'."\r\n";
echo "\t\t".'<ul>'."\r\n";
/* fetch values */
while ($beyan->fetch())
{
echo "\t\t\t".'<li>'.'<a href="'.sitenin_koku.'yazılar/'.bosluklar_tire_olsun($yazar).'/'.bosluklar_tire_olsun(noktalamasiz($baslik)).'">'.$baslik.'</a>'.' - '.turkcetarih('j F Y',$ytarihi).'</li>'."\r\n";
}
echo "\t\t".'</ul>'."\r\n";
echo "\t".'</div>'."\r\n";
/* close statement */
$beyan->close();
}
else {echo "Hazırlama hatası: (" . $db_baglanti->errno . ") " . $db_baglanti->error;}
解析错误:语法错误,意外'',?,''(T_CONSTANT_ENCAPSED_STRING)在...第2行...中我需要你的帮助,因为我甚至无法解决我的情况堆栈溢出或googleing。
感谢
BR
答案 0 :(得分:3)
语法高亮文本编辑器可以帮助你。
您"
嵌套在"
内。他们需要像\"
一样进行转义。
$sorgum = "SELECT kolon_yazar, kolon_baslik, kolon_ytarihi FROM tb_yazilar WHERE kolon_etiketler REGEXP CONCAT('[[:<:]]\"', ?, '\"[[:>:]]') AND kolon_statu = ? ORDER by kolon_onaytarihi DESC";