勉強したことのメモ

webプログラマ見習いが勉強したことのメモ。

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

      2014/05/22

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

で、回答するほうは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型・添字配列・連想配列)
がいけるらしいので絶対便利。

 - MySQL, PHP

  関連記事

ディレクトリに設置してあるフォルダをPHPで調べて表示

やりたい事はsampleというディレクトリがあったとして、その直下にあるフォルダ ...

PHPでのcookie

aaa.comにログインフォームがあって、IDパスを入れて ログインするとbbb ...

WordPressサイトのロードアベレージが高い

あるWordPressサイトのロードアベレージが先月ぐらいまでは通常0.5前後で ...

PHPでランダムな値を取得するケース諸々

テストデータを作成する際に、ランダムな値を入れたかったけど、 色々ケースがあった ...

MySQLでtext型カラムに入っている数値をint型としてソートする

MySQLでtext型として指定されているカラムがあり、その中には文字列であった ...

Basic認証がかかっているファイルをPHPで認証突破と取得

Aというサイトにあるベーシック認証がかかっているディレクトリ内のファイルを、Bと ...

PHPでサイトマップを動的に生成する

WordPress等のCMSは使っておらず、自動更新するサイトがあり、そのサイト ...

PHPでCSVファイル出力用の関数

ここのところログ系をCSVファイル出力にするケースが多かった為、使いまわせるよう ...

テンポラリテーブルで高速化

5000万件ぐらいデータが入っているテーブルから 日本語検索しないといけないケー ...

PHPで指定月の月末日を取得

今月の、だったらdate('t')でいくけど指定月の場合は どうしたらいいのか分 ...