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

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

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

Objective-Cはオブジェクト指向型のプログラミング言語のひとつです。C言語をベースにSmalltalkが取り入れられています。

SQLite

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

Q&A

解決済

2回答

4774閲覧

SQLiteで一つだけ行を削除する

tarofess

総合スコア127

Objective-C

Objective-Cはオブジェクト指向型のプログラミング言語のひとつです。C言語をベースにSmalltalkが取り入れられています。

SQLite

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

0グッド

1クリップ

投稿2015/08/26 06:26

編集2015/08/26 06:50

SQLiteで一つだけ行を削除したいのですが、以下のようにすると
「1 "near "LIMIT": syntax error"」
というエラーが返ってきます。

objective

1"DELETE FROM OrderItems WHERE productName = '%@' LIMIT %d", orderItemsName, deleteItemNum

また、以下のようにすると、指定したカラムの全てのデータが消えてしまいます。

objective

1"DELETE FROM OrderItems WHERE productName IN (SELECT productName FROM OrderItems WHERE productName = '%@' LIMIT 1)", orderItemsName

色々と調べてみても削除したい行の数を指定して削除するやり方があまり載っておらず、どうすればいいか分かりません。
どうすればあるカラムのデータ一つだけを削除することができるでしょうか?
どなたか分かる方がいれば教えていただきたいです。
すみませんが、宜しくお願いします。

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

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

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

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

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

guest

回答2

0

stackoverflowによると、普通のsqlite3ではdelete...limitが使えないようです。
方法はselect ... limit 1で一つ分のプライマリキーをとってきてdeleteするか、
フルバージョンを自分でビルドするかですね。

投稿2015/08/26 07:02

ikeyan

総合スコア136

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

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

tarofess

2015/08/26 07:17

ご回答ありがとうございます。delete limitは使えないのですね......。 ではやり方を変えたいと思います。ありがとうございます。
guest

0

ベストアンサー

主キーがあるテーブルなら主キーを指定すれば1件消えますが
主キーのないテーブルなのでしょうか?

また、主キーがないなら主キーを作ることはできないのでしょうか?

主キーがないならROWIDを使ってもいいと思います

DELETE FROM OrderItems WHERE ROWID = (SELECT ROWID FROM OrderItems WHERE productName = '%@' LIMIT 1)", orderItemsName

投稿2015/08/26 06:55

編集2015/08/26 06:59
kutsulog

総合スコア985

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

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

tarofess

2015/08/26 07:19

ご回答ありがとうございます。主キーはあるのですが、今主キーを参照したら少し複雑になる作りになってしまっていて、主キーを使わずにやろうと思ったのですが、やはり主キーを使うことにします。ご提示のROWIDのやり方も参考にさせていただきます。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問