
No.1ベストアンサー
- 回答日時:
単純にifで場合分けするだけでしょうね、以下例
//元データ
create table tbl (id int not null auto_increment primary key,data varchar(30),flg tinyint not null);
insert into tbl(id,data) values(1,'a'),(2,'b'),(3,'c');
select * from tbl;
id,data,flg
1,a,0
2,b,0
3,c,0
//id=4,dataを'x'を挿入
insert into tbl (id,data) values(4,@data:='x')
on duplicate key update data=if(flg=0,@data,data);
select * from tbl;
id,data,flg
1,a,0
2,b,0
3,c,0
4,x,0
//id=4のdataを'y'に更新、ただしflgが0の場合→flgは0なので更新
insert into tbl (id,data) values(4,@data:='y')
on duplicate key update data=if(flg=0,@data,data);
select * from tbl;
id,data,flg
1,a,0
2,b,0
3,c,0
4,y,0
//id=4のdataを'z'に更新、ただしflgが1の場合→flgは0なので更新されない
insert into tbl (id,data) values(4,@data:='z')
on duplicate key update data=if(flg=1,@data,data);
select * from tbl;
id,data,flg
1,a,0
2,b,0
3,c,0
4,y,0
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
select文のwhere句に配列を入れ...
-
クエリ表示と、ADOで抽出したレ...
-
エクセルの関数について教えて...
-
エラー 1068 (42000): 複数の主...
-
SQLサーバから、項目の属性(型...
-
ソート順の一番若い者を取得する
-
ストアドのエラーについて
-
”photo id” とは何ぞや?
-
PL/SQLの変数について
-
NOT INをNOT EXISTSで書き直したい
-
「SELECTして取得できない場合...
-
selectした大量データをinsert...
-
Postgreのupdateコマンドでエラー
-
Unionした最後にGROUP BYを追加...
-
WordpressのContact form 7でzi...
-
【Transact-sql】 execの結果を...
-
#1136 - Column count doesn't ...
-
メルペイとメルペイid決済の違...
-
Pro COBOLでは、最後執行したS...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
エクセルの関数について教えて...
-
VIEWの元のテーブルのindexって...
-
エラー 1068 (42000): 複数の主...
-
SQLサーバから、項目の属性(型...
-
select文のwhere句に配列を入れ...
-
SQL Left Join で重複を排除す...
-
Access パラメータクエリをcsv...
-
マイクラPC版のコマンドで効率...
-
【Transact-sql】 execの結果を...
-
sqlで、600行あるテーブルを100...
-
SQLにて特定の文字を除いた検索...
-
1テーブル&複数レコードの更新...
-
PL/SQLの変数について
-
WordpressのContact form 7でzi...
-
複数テーブルのGROUP BY の使い...
-
バインド変数について
-
inner joinをすると数がおかし...
-
MySQLのint型で001と表示する方...
-
updateを1行ずつ実行したい。
おすすめ情報