Search code examples
sqliteinsertexistsupsertmerge-conflict-resolution

INSERT IF NOT EXISTS ELSE UPDATE?


I've found a few "would be" solutions for the classic "How do I insert a new record or update one if it already exists" but I cannot get any of them to work in SQLite.

I have a table defined as follows:

CREATE TABLE Book 
ID     INTEGER PRIMARY KEY AUTOINCREMENT,
Name   VARCHAR(60) UNIQUE,
TypeID INTEGER,
Level  INTEGER,
Seen   INTEGER

What I want to do is add a record with a unique Name. If the Name already exists, I want to modify the fields.

Can somebody tell me how to do this please?


Solution

  • Have a look at http://sqlite.org/lang_conflict.html.

    You want something like:

    insert or replace into Book (ID, Name, TypeID, Level, Seen) values
    ((select ID from Book where Name = "SearchName"), "SearchName", ...);
    

    Note that any field not in the insert list will be set to NULL if the row already exists in the table. This is why there's a subselect for the ID column: In the replacement case the statement would set it to NULL and then a fresh ID would be allocated.

    This approach can also be used if you want to leave particular field values alone if the row in the replacement case but set the field to NULL in the insert case.

    For example, assuming you want to leave Seen alone:

    insert or replace into Book (ID, Name, TypeID, Level, Seen) values (
       (select ID from Book where Name = "SearchName"),
       "SearchName",
        5,
        6,
        (select Seen from Book where Name = "SearchName"));