勉強したことのメモ

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

1回のSQL文で複数のUPDATE

      2014/07/03

INSERTはバルクインサートを使えばいいが、
UPDATEはあまり聞かないので調べたところ、
一括で出来るものを発見。

$sql = "
UPDATE テーブル名
SET calam_num=
(CASE calam_seq
WHEN seq_1 THEN num_1 WHEN seq_2 THEN num_2 ...
ELSE calam_num END);
";

でUPDATEできる。

WHENのところでseqを指定して、該当seqのnumを書き換える。

やりたかった事は、

----------
numが連番になっているところを途中のカラムを削除
↓↓
欠番が出るので、削除したカラム以降のnumを+1する
----------

で、↓↓でとりあえずは解決できた。

//欠番を埋める為、SQL文の中身をループで作成
for($i=1; $i<=count($sort_seq); $i++){
$sort_sql .= 'WHEN '.$sort_seq[$i-1].' THEN '.$i.' ';
}

//ソート順を欠番を埋めて並びかえ
$sql = "
UPDATE テーブル名
SET num=
(CASE seq
$sort_sql
ELSE num END);
";

尚、他にも方法はあるみたいなので、機会を見て検証する。

↓↓

http://d.hatena.ne.jp/IT7C/20100703/1278125750

 - MySQL

  関連記事

msyql-image
phpMyAdminやAdminer上だけ文字化け

レンタルサーバーのプログラムでWebページ上では文字化けしていないのに、phpM ...

msyql-image
MySQLで加算しつつNULL値は0にする

いくつかのコードに対して投票を行い、 その合計値をスコアとして出したい。 ただ、 ...

msyql-image
MySQLでIPを整数値としてカラムに格納する

MySQLでIPを整数値としてカラムに格納しているケースがあった。今までIPが必 ...

msyql-image
MySQLでテーブル構造とデータをコピーする

MySQLで既にあるテーブルとデータに対して実験を行う必要があった。本番テーブル ...

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

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

msyql-image
LEFT JOIN

なんとなくで覚えていたMySQLのLEFT JOINを 最近使うことがあり、上手 ...

msyql-image
コマンドでMySQLに郵便番号データを入れる

練習としてコマンドから郵便番号データを入れた際のメモ。 --------- 1: ...

msyql-image
MySQLでカラム内容によって条件分岐させたい

MySQLでカラムの内容によって条件を分岐させたかった。またPHPで処理するので ...

msyql-image
MySQLでグループ化したものを条件で絞る(HAVING)

正規化したテーブルがあってその中には idとtagのカラムがある。 でtagの方 ...

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

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