MySQL のシリアル化された配列項目に基づくレコードの取得
データベース フィールド内のシリアル化された配列にデータを保存すると便利ですが、課題が生じます特定の配列項目に基づいてレコードを取得しようとするとき。従来の SQL 構文では、配列要素を直接フィルタリングすることはできません。
解決策: LIKE 句を使用する
コメンテーターが示唆しているように、代替のデータ ストレージ方法を検討することが最適です。ただし、すぐに変更することが不可能な場合は、シリアル化された配列が本質的に文字列であるという事実を利用できます。 PHP シリアル化形式 (数値の長さインジケーターを使用) を調べることで、一致するレコードを見つけるための LIKE 句を作成できます。
例:
次の例を考えてみましょう。
select * from table WHERE serialized_array LIKE '%s:1:"n";s:1:"$n";%'
この例では、キー「n」に対応する配列値が「$n」であるレコードを対象とします。ただし、このアプローチには制限があることに注意することが重要です。
結論:
LIKE 句を使用すると即時クエリの要件に対処できますが、代替のデータ ストレージ アプローチを検討する必要性が強調されます。構造化クエリを有効にしてパフォーマンスと保守性を向上させます。
以上がMySQL でシリアル化された配列項目に基づいてレコードを取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。