MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。
Q&A
解決済
1回答
3675閲覧
総合スコア23
0グッド
0クリップ
投稿2014/05/25 15:15
0
MySQLを使ってwebアプリケーションを作成しているのですが データをMySQLに格納する際に、 同じid(primary key)が存在すればUPDATE文で、 無ければINSERT文として実行という処理を行いたいのですが、 どうしたらいいのでしょうか?
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
質問へのコメント
回答1件
ベストアンサー
tableの中に必ずprimary keyかunique keyが必要ですが、 duplicate keyを使うことで可能です。
たとえば users(table名)に、id=1000がまだなければname=Taro、 既に存在していればname=Hanakoにしたい場合(おかしなシチュエーションですが)、 以下のようなSQL文で実行できます。
insert into users (id, name ) values ('1000', 'Taro') on duplicate key update id='1000', name='Hanako';
投稿2014/06/03 03:01
総合スコア90
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
15分調べてもわからないことはteratailで質問しよう!
ただいまの回答率85.29%
質問をまとめることで思考を整理して素早く解決
テンプレート機能で簡単に質問をまとめる
MySQLで既に値があればUPDATE、無ければINSERTという処理をしたい!
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。