php資料庫輸出問題

來源:互聯網
上載者:User
$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文法出錯了。

弄清楚單引號和雙引號的用法就知道了。

  • 相關文章

    聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.