勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

PHPからMySQLにシリアライズしたデータを格納

   2014/05/22  PHP MySQL

アンケートフォームみたいなのがあって、
今後も定期開催し、尚且つ質問内容は増減する
可能性があった。

で、回答するほうは3~のテキストボックス。
今は3つだけど今後は増えるかもしれないし減るかもしれない。
で、それをデータベースに突っ込みたかった。

今までは回答を受け取ってカンマ区切りとかにして
DBに突っ込んでたけど、以前先輩から「カンマ区切りは
いけてない。正規化できないならせめてシリアライズしなさい」
と言われたことを思い出して試したところ便利だった。

■参考サイト
http://suin.asia/2011/08/09/4_tips_to_preserve_array_as_string

$ans = serialize($_GET['answer']);
$sql = '
INSERT INTO テーブル
(
answer
)
VALUES
(
"' . mysql_real_escape_string($ans) . '",
)
;

エスケープとかどうなるの、と思ったけど上記の形でいけた。
MySQLの方は文字列タイプでいけるみたいなので、
text型でいった。多分varcharでも大丈夫そう。

あと、文字列扱いだったらカンマ区切りとあんま変わらへんのでは?
と思ったけど、よくよく見ると多数の型(bool型・int型・float型・string型・添字配列・連想配列)
がいけるらしいので絶対便利。

 - PHP MySQL

  関連記事

MySQLにてSELECT時にdate型のカラムから年齢を計算し取得する方法

MySQLにdate型のカラムに誕生年月日が格納されており、そこから年齢を計算し ...

MySQLでテキスト(日本語、半角英数字)を暗号化・復号化する方法

MySQLでデータを登録する際に暗号化したいというケースがあった。対象のデータは ...

MySQLのトリガーを使用して特定のテーブルの操作を行った際に別テーブルにログを残す方法

MySQLにトリガーという機能があるらしくどのようなものか調べたところ、事前に「 ...

MySQLで開始から終了日付内を調べたいとき

等号不等号でもできるけど、BETWEENというのがよさそう。 ■参考サイト ht ...

MySQLのバイナリログ(/var/lib/mysql/binlog)を適切に削除する方法

レンタルしているVPS内のファイルを整理していると「/var/lib/mysql ...