PDO を使用した MySQL の数値型の取得
PDO を使用して MySQL から数値型を取得することは、文字列表現を返すデフォルトの動作により困難になる場合があります数値の代わりにvalue.
PDO::ATTR_STRINGIFY_FETCHES 属性
PDO クラスは、数値から文字列への変換を制御する PDO::ATTR_STRINGIFY_FETCHES 属性を提供します。ただし、この属性は MySQL ドライバーではサポートされていません。
プリペアド ステートメント エミュレーションの無効化
数値型を正しく取得するには、PDO からプリペアド ステートメント エミュレーションを無効にする必要があります。これは、PDO オブジェクトの作成時に PDO::ATTR_EMULATE_PREPARES を false に設定することで実現できます。
$pdo = new PDO($dsn, $user, $pass, [ PDO::ATTR_EMULATE_PREPARES => false, ]);
プリペアド ステートメント エミュレーションを無効にすると、PHP は数値型を含むネイティブ MySQL データ型を利用します。今後、データベースから取得した int 値は文字列に変換されなくなります。
結論
数値型の一貫した処理を確保するには、プリペアド ステートメントを無効にすることをお勧めします。 PDO および MySQL を使用する場合のエミュレーション。これにより、数値を実際の形式で確実に取得できるようになり、データ処理の精度と使いやすさが向上します。
以上が文字列変換を行わずに PDO を使用して MySQL から数値型を取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。