質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.48%
SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

解決済

3回答

5254閲覧

sqlite3で重複レコードを回避してINSERTする方法

python_a

総合スコア12

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2019/07/31 04:51

編集2019/07/31 05:20

sqlite3でレコードが
・重複していない場合はレコードを新たに追加
・重複している場合はカウンターにプラス1を行う
という処理を行いたいと考えています。

カラムは以下の通りです。
ID, data1, data2, data3, counter

data1、data2、data3の3つのデータで重複を判断し、
3つのデータが全て重複する場合はカウンターにプラス1します。
3つのうち、1つでもデータが異なる場合は、レコードを追加します。

ネット上のあらゆるSQL文を試してみたのですが、上手くいかず困っております。
どうぞよろしくお願いいたします。

参考にした記事はこちらです。
http://scrap.php.xdomain.jp/exists_insert/

試したSQL文です。
cur.execute("""
UPDATE table1 SET counter = counter + 1 WHERE EXISTS (
SELECT * FROM table1
WHERE table1.data1 = '{0}' AND table1.data2 = '{1}' AND table1.data3 = '{2}'
);""".format(data1,data2,data3))

cur.execute("""
INSERT INTO table1 (data1, data2, data3) SELECT '{0}', '{1}', '{2}'
FROM table1 WHERE NOT SELECT EXISTS(
SELECT * FROM table1 WHERE data1='{0}' AND data2='{1}' AND data3='{2}'
);""".format(data1, data2, data3))

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

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

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

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

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

m.ts10806

2019/07/31 04:53

タグはPythonではなくSQLiteでは? また「ネット上の」参考にした記事と実際に試したSQLをご提示ください。
python_a

2019/07/31 05:06

すいません。タグを間違えました。 参考にした記事はこちらです。 http://scrap.php.xdomain.jp/exists_insert/ 試したSQL文です。 cur.execute(""" UPDATE table1 SET counter = counter + 1 WHERE EXISTS ( SELECT * FROM table1 WHERE table1.data1 = '{0}' AND table1.data2 = '{1}' AND table1.data3 = '{2}' );""".format(data1,data2,data3)) cur.execute(""" INSERT INTO table1 (data1, data2, data3) SELECT '{0}', '{1}', '{2}'   FROM table1 WHERE NOT SELECT EXISTS( SELECT * FROM table1 WHERE data1='{0}' AND data2='{1}' AND data3='{2}' );""".format(data1, data2, data3))
m.ts10806

2019/07/31 05:10

SQLについても質問本文に追記願います。
python_a

2019/07/31 05:22

失礼しました。追記致しました。
guest

回答3

0

data1,data2,data3をプライマリーにすればinsert replace into使えるけどidのみをプライマリーなら無理だなsqliteだけじゃ対応無理だな、それにcounterの事考えても面倒くさい

投稿2019/07/31 05:20

hentaiman

総合スコア6421

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

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

python_a

2019/07/31 05:23

やはりプライマリキーを見直した方が良さそうですね。 ありがとうございます。
hentaiman

2019/07/31 05:28

問題はそこよりもっと前の設計の部分にありそうだけど、動けばなんでもいいんじゃない
python_a

2019/07/31 23:39

確かに設計も未熟です。 とりあえずは、プライマリキーを見直して動きました。
guest

0

ベストアンサー

'data1、data2、data3の3つのデータで重複を判断し'
ということなら、この3つを連結したものをIDと定義すれば話は簡単ではないでしょうか。

投稿2019/07/31 05:09

KojiDoi

総合スコア13671

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

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

python_a

2019/07/31 05:14

確かにそんな手がありますね。 ただ、データを取り出すときに、それぞれのデータに応じてGROUP BYで取り出したいと考えているので、 できればカラムを分けたいと思っております。
python_a

2019/07/31 05:18

すいません。回答を取り違えていました。 確かにその方法を使えば、簡単にわけることができそうですね。 ありがとうございます。
guest

0

sqlite3でレコードが

・重複していない場合はレコードを新たに追加
・重複している場合はカウンターにプラス1を行う
という処理を行いたいと考えています。

素直に、「SELECTしてから、なければINSERT、あればUPDATE」というような処理を書きましょう。

投稿2019/07/31 04:56

編集2019/07/31 04:57
maisumakun

総合スコア145184

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

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

python_a

2019/07/31 05:18

確かに一度取り出してしまえば、簡単にできそうですね。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問