Mysqli の準備エラーの問題について専門家のアドバイスを提供してください
久しぶりにプログラムを書きましたが、php5.0でバージョンアップしたmysqliクラスはデータベースを操作する上でメリットが多いので、情報を確認した上でmysqliメソッドを使ってデータベースを操作してみたいと思います。インターネットとマニュアルの閲覧、閲覧と削除が正常に実行できるのは、挿入関数のみで常にエラーが表示される場合です: Fatal error: Call to a member function prepare() on null in D:xamppshtdocstxladdbook.php on line 20 。
この問題が解決できない場合、Mysqli を諦めるべきでしょうか?私のコードのどこが間違っているのか教えていただけますか?それともサーバーの問題でしょうか? (サーバーには統合環境 Xampps1.9.7 を使用しています)
if($_POST['contacts'] == "true")
{
$stmt = $mysqli->prepare("INSERT INTO contactsuser(bookUname, bookDep , bookDuty,bookphone,bookTel,bookEmail,bookGid) VALUES (?, ?, ?, ?, ?, ?, ?)");
$stmt->bind_param('sssd', $bookUname, $bookDep, $ bookDuty、$bookphone、$bookTel、$bookEmail、$bookGid);
$bookUname = $_POST['bookDep']
$bookDuty = $_POST'; ] ;
$bookphone = $_POST['bookphone'];
$bookEmail = $_POST['bookGid'];
/* 準備されたステートメントを実行します */
$stmt->execute();
printf("%d Row Inserted.n", $stmt->affected_rows);
/* ステートメントと接続を閉じます */ $stmt ->close();
exit
}
ディスカッションへの返信 (解決策)
$mysqli は mysqli オブジェクトではありません手続き型のアプローチを試してください:
$stmt = mysqli_prepare($link, "INSERT INTO contactsuser(bookUname, bookDep, bookDuty,bookphone,bookTel,bookEmail,bookGid) VALUES (?, ?, ?, ?, ?, ?, ?)")
たった今の私のプログラムうっかりデータベース リンク ファイルを含めるのを忘れたのは事実ですが、プロセス指向スタイルへの変更を含め、データベース リンク ファイルを含めた後も、依然としてエラーが発生します。
警告: mysqli_stmt_bind_param(): 型定義文字列内の要素の数が一致しません。 D のバインド変数の数を照合します: xamppshtdocstxladdbook.php の 24 行目
$link = mysqli_connect('localhost','root','root','addressbook') または die('Unale to connect');
$stmt = mysqli_prepare($ link, "INSERT INTO contactsuser(bookUname, bookDep, bookDuty,bookphone,bookTel,bookEmail,bookGid) VALUES (?, ?, ?, ?, ?, ?, ?)") ;
mysqli_stmt_bind_param($stmt, 'sssd', $bookUname, $bookDep, $bookDuty, $bookphone, $bookTel, $bookEmail, $bookGid);
$bookUname = $_POST['bookDep']; _POST['bookDep'];
$bookDuty = $_POST['bookphone'];
$bookTel = $_POST['bookTel']; 'bookEmail'];
$bookGid = 1;
mysqli_stmt_close($stmt);
主キー bookid が int 型であることを除き、増加、bookGid は int 型、その他はすべて varchar 型です
VALUES (? , ?, ?, ?, ?, ?, ?)
$stmt,'sssd', $bookUname, $bookDep, $bookDuty, $bookphone、$bookTel、$bookEmail、$bookGid
7 つの疑問符は 8 つのパラメータに対応します。 。 。 。 。疑問符を追加して再試行してください
mysqli_stmt_bind_param($stmt,'ssssssd', $bookUname, $bookDep, $bookDuty, $bookphone, $bookTel, $bookEmail, $bookGid);
http://php.net/manual/zh/mysqli-stmt.bind-param.php
変数の数と文字列型の長さは、次のパラメータと一致する必要があります上の人は正しいです、それはssssssdであるはずです
素晴らしい!ご協力いただきました専門家の皆様に感謝いたします。特にsaint_leerとmisakaqunianx...彼らが言及した「ssssssd」の問題は的を射ていますが、文字列を渡すことが何を意味するのか私はまだ理解していません。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

PHP開発でPHPのCurlライブラリを使用してJSONデータを送信すると、外部APIと対話する必要があることがよくあります。一般的な方法の1つは、Curlライブラリを使用して投稿を送信することです。

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。

phpstormでCLIモードをデバッグする方法は? PHPStormで開発するときは、PHPをコマンドラインインターフェイス(CLI)モードでデバッグする必要がある場合があります。
