php 寫入資料庫時Call to a member function bind_param() on a non-object

來源:互聯網
上載者:User

標籤:

<?php$servername = "localhost";$username = "username";$password = "password";$dbname = "myDB";// 建立串連$conn = new mysqli($servername, $username, $password, $dbname);// 檢測串連if ($conn->connect_error) {die("Connection failed: " . $conn->connect_error);}// prepare and bind$stmt = $conn->prepare("INSERT INTO MyGuests VALUES(?, ?, ?)");$stmt->bind_param("sss", $firstname, $lastname, $email);// 設定參數並執行$firstname = "John";$lastname = "Doe";$email = "[email protected]";$stmt->execute();$firstname = "Mary";$lastname = "Moe";$email = "[email protected]";$stmt->execute();$firstname = "Julie";$lastname = "Dooley";$email = "[email protected]";$stmt->execute();echo "New records created successfully";$stmt->close();$conn->close();?>

 運行時報錯:

Call to a member function bind_param() on a non-object

原因:
bind_param 的第二個參數是起引用傳遞的
直接寫成字串,這是在 php 5.3 及以後是不允許的

解決方案:
將 $stmt = $conn->prepare("INSERT INTO myguests VALUES(?,?,?)");
改成$stmt = $conn->prepare("INSERT INTO myguests(firstname, lastname, email) VALUES(?,?,?)");

php 寫入資料庫時Call to a member function bind_param() on a non-object

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.