$result = mysql_query('"SELECT * FROM jo_postWHERE id='.$id.'"');
這樣為什麼無法輸出資料庫內容?
回複內容:
$result = mysql_query('"SELECT * FROM jo_postWHERE id='.$id.'"');
這樣為什麼無法輸出資料庫內容?
PHP中三種主要的MySQL串連方式(5.4開始驅動底層實現都是mysqlnd):
http://php.net/manual/zh/mysqli.overview.php
mysqli(首選) pdo_mysql(建議) mysql(不建議)
PHP7已經不支援mysql擴充了,推薦樓主改用mysqli擴充.
另外,樓主直接拼接字串作為SQL查詢條件,存在SQL注入風險,建議先intval轉為整型,或者使用預先處理綁定參數查詢.
query('SELECT * FROM post WHERE id='.intval($id))->fetch_all());//MySQLi綁定參數查詢:$db = @new mysqli('127.0.0.1','user','pass','dbname',3306);$stmt = $db->prepare('SELECT * FROM posts WHERE id=?'); //預先處理$stmt->bind_param('i', $id); //綁定參數(可以防止SQL注入)$stmt->execute(); //查詢var_export($stmt->get_result()->fetch_all());
$result = mysql_query("SELECT * FROM jo_post WHERE id=$id");
你這跟mysql的交談方式不對啊
你先試試echo '"SELECT * FROM jo_postWHERE id='.$id.'"';
然後讓mysql執行一下
select語句應該是個關鍵字吧,你把他當作字串了
按你的寫發,你執行的是 "SELECT * FROM jo_post WHERE id=xx" 包括了這兩個引號
將你$result變數,用echo語句輸出到螢幕,然後複製出來,在mysql管理介面(常用phpmyadmin)中打到對應的資料表,開啟SQL菜單,粘貼這個變數的SQL語句,執行一下,就可以知道這個語句對不對,一般SQL語句書寫要用雙引號和單引號時,雙引號在外,單引號在內。你輸出不了資料內容,就是SQL文法出錯了。
弄清楚單引號和雙引號的用法就知道了。