🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
INSERT

INSERTとは、行を追加する、コンピュータのデータベース言語SQLにおけるデータ操作言語(DML)ステートメントの1つである

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

2回答

2464閲覧

MySQL INSERT ~ ON DUPLICATE KEY UPDATE での一括更新

cali

総合スコア4

INSERT

INSERTとは、行を追加する、コンピュータのデータベース言語SQLにおけるデータ操作言語(DML)ステートメントの1つである

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

2クリップ

投稿2019/11/04 11:12

編集2019/11/05 04:35

前提・実現したいこと

pythonからmysqlを操作し
table内のUNIQUEキーが重複したらUPDATE
重複しなければINSERTしたい。
INSERT ~ ON DUPLICATE KEY UPDATE
を使用すれば可能とのことだったが、どうしてもうまくいきません。
助けてください。。。

以下、gをUNIQUEキーとしてgの重複有無

発生している問題・エラーメッセージ

mysql.connector.errors.ProgrammingError: 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near...

該当のソースコード

python

1import mysql.connector 2 3table_name = "test" 4db_settings = { 5 "host":"localhost", 6 "database":"test01", 7 "user":"testuser", 8 "password":"******", 9 "port":3306 10} 11 12conn = mysql.connector.connect(**db_settings) 13cur = conn.cursor() 14sql = "INSERT INTO table_name ( a, b, c, d, e, f, g) VALUES (%(a)s, %(b)s, %(c)s, %(d)s, %(e)s, %(f)s, %(g)s) ON DUPLICATE KEY UPDATE d = values(d),e = values(e),f = values(f)" 15 16#info内は辞書tuple 17info = [{ a:int01, b:text02, c:text03, d:int04, e:int05, f:int06, g:text07}, 18 {+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++}, 19 {+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++}, 20 {+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++}, 21 {+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++}, 22 ... 23 ] 24 25for content in info: 26 cur.execute(sql,{ 27 'a':content['a'], 28 'b':content['b'], 29 'c':content['c'], 30 'd':content['d'], 31 'e':content['e'], 32 'f':content['f'], 33 'g':content['g'], 34 'd':content['d'], 35 'e':content['e'], 36 'f':content['f'], 37 }) 38 39conn.commit() 40conn.close

補足情報(FW/ツールのバージョンなど)

table内は以下

mysql> show fields from test;
+---------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+---------+--------------+------+-----+---------+----------------+
| a | int(11) | NO | PRI | NULL | auto_increment |
| b | text | YES | | NULL | |
| c | text | YES | | NULL | |
| d | int(11) | YES | | NULL | |
| e | int(11) | YES | | NULL | |
| f | int(11) | YES | | NULL | |
| g | text | YES | UNI | NULL | |
+---------+--------------+------+-----+---------+----------------+

追記

以下、insert文で実行すると問題なくDBへのinsertが行われています。
INSERT ~ ON DUPLICATE KEY UPDATE文でエラーを起こしているとは思うのですが、、、
わかりません。。

python

1sql_insert = 'insert into test values(%(a)s, %(b)s, %(c)s, %(d)s, %(e)s, %(f)s, %(g)s' 2cur.execute(sql_insert,{ 3 'a':content['a'], 4 'b':content['b'], 5 'c':content['c'], 6 'd':content['d'], 7 'e':content['e'], 8 'f':content['f'], 9 'g':content['g'], 10 })

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

javahack

2019/11/04 17:28

エラーメッセージの重要な箇所が省略されてしまっているので、全文を省略なしで修正して記載していただくと回答が得られやすくなると思います。
cali

2019/11/04 17:49

指摘ありがとうございます。 mysql.connector.errors.ProgrammingError: 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'e, f, g) VALUES (%(a)s, %(b)s' at line 1 (%(a)s, %(b)s'  内には辞書内の値が入っています。
m.ts10806

2019/11/04 21:06

SQLの構文エラーなのは明らかです。 「想定しているSQL」通りにSQLができあがるコードになっているかを確認してください。 また、固定値などを入れて「想定しているSQL」は作って実行は成功しているのでしょうか?
guest

回答2

0

You have an error in your SQL syntax;

syntaxとは構文のことで、SQLの構文エラーです。す。こういう場合はSQLのエラーコードを検索した方がいいと思います(けっこうエラーコードはDBで共通だったりしており、エラーコード42000は構文自体がおかしい、という最も典型的なエラーです)。

では、そのSQL文を見てみると

SQL

1INSERT INTO table_name ( a, b, c, d, e, f, g) VALUES (%(a)s, %(b)s, %(c)s, %(d)s, %(e)s, %(f)s, %(g)s) 2ON DUPLICATE KEY 3UPDATE d = values(d),e = values(e),f = values(f)

となっています。リファレンスで確認してみて、まずはエラーが表示されている辺りのカンマや括弧などが全角になっていたりしないか確認してみたらいいと思います。

13.2.5.3 INSERT ... ON DUPLICATE KEY UPDATE 構文

投稿2019/11/05 01:31

編集2019/11/05 01:52
FKM

総合スコア3647

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yambejp

2019/11/05 01:40

Insert ~ on duplicate key updateの構文なので update構文は関係ないかと・・・
FKM

2019/11/05 01:53

そうですね、省略記法が使えるみたいなので、記事を修正しました。
guest

0

とりあえず

sql = "INSERT INTO table_name ( a, b, c, d, e, f, g) VALUES (1,'b','c',2,3,4,'g') ON DUPLICATE KEY UPDATE d = values(d),e = values(e),f = values(f)"

のように具体的な値を入れてテストするところからでしょうか

投稿2019/11/05 01:28

yambejp

総合スコア116661

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問