[解決済み】SQLiteの "Insert if not exists "ステートメントについて
2022-04-12 07:28:26
質問
SQLiteデータベースを持っています。私は値を挿入しようとしています (
users_id
,
lessoninfo_id
) のテーブルで
bookmarks
ただし、両者が同じ行に存在しない場合に限ります。
INSERT INTO bookmarks(users_id,lessoninfo_id)
VALUES(
(SELECT _id FROM Users WHERE User='"+$('#user_lesson').html()+"'),
(SELECT _id FROM lessoninfo
WHERE Lesson="+lesson_no+" AND cast(starttime AS int)="+Math.floor(result_set.rows.item(markerCount-1).starttime)+")
WHERE NOT EXISTS (
SELECT users_id,lessoninfo_id from bookmarks
WHERE users_id=(SELECT _id FROM Users
WHERE User='"+$('#user_lesson').html()+"') AND lessoninfo_id=(
SELECT _id FROM lessoninfo
WHERE Lesson="+lesson_no+")))
というエラーが出ます。
where 構文付近で db エラーが発生しました。
解決方法は?
memosというテーブルがあり、2つのカラムがあるとします。
id
と
text
というようなことができるはずです。
INSERT INTO memos(id,text)
SELECT 5, 'text to insert'
WHERE NOT EXISTS(SELECT 1 FROM memos WHERE id = 5 AND text = 'text to insert');
レコードにすでに
text
が '挿入するテキスト' と等しく、かつ
id
が5である場合、挿入操作は無視されます。
この方法があなたの特定のクエリに有効かどうかは分かりませんが、おそらく進め方のヒントになるはずです。
で説明されているように、重複を許さないようにテーブルを設計することをお勧めします。
@CLs answer
を以下に示します。
関連
-
SQLiteのエラーコードのソート
-
SQLite3 用に ANSI から UTF8 への交換関数を提供する。
-
SQLiteチュートリアル(I)。SQLiteデータベース入門
-
SQLiteで自動番号付けされたカラムをリセットする方法
-
[解決済み] SQLiteのINSERT/per-secondのパフォーマンスを向上させる
-
[解決済み] ATTACHで開いたSQLiteデータベースファイルのテーブルを一覧表示するにはどうすればよいですか?
-
[解決済み] SQLiteでテーブルが存在するかどうかを確認するにはどうすればよいですか?
-
[解決済み] MySQLで'insert if not exists'を行うにはどうしたらいいですか?
-
[解決済み] SQLite - UPSERT *not* INSERT or REPLACE
-
[解決済み】SQLite:クエリの結果をCSVファイルとして保存する方法は?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
ESCAPE を使用して SQL でエスケープを定義する
-
ubuntuでSQLite3を使うための基本コマンド
-
SQLiteチュートリアル(X)。インメモリデータベースとテンポラリデータベース
-
Sqliteデータベースの最大挿入データ数は500個です。
-
SQLiteで自動番号付けされたカラムをリセットする方法
-
SQLiteチュートリアル(3)。データテーブルとビューの紹介
-
[解決済み] Sqlite3の文字列比較で大文字・小文字を区別しない設定にするには?
-
[解決済み】SQLite:クエリの結果をCSVファイルとして保存する方法は?
-
[解決済み] SQLiteの主キーにはインデックスが必要ですか?
-
[解決済み] SQLite 3.0でテーブルの名前を変更するにはどうすればよいですか?