In my table, id
is the primary key, but this code not working in sqlite3:
insert into text (id,text) VALUES(150574,\'Hello\') ON DUPLICATE KEY U
Since SQLite version 3.24.0 (released 2018-06-04) there is ON CONFLICT
support modeled after PostgreSQL. See documentation for more details.
INSERT .... ON DUPLICATE
don't exist in SqLite. But you can use INSERT OR REPLACE
to achieve the effect like the following.
INSERT
OR REPLACE
INTO
text (id, text)
VALUES
(150574,
(SELECT
CASE
WHEN exists(SELECT 1 FROM text WHERE id=150574)
THEN 'good'
ELSE 'Hello'
END
)
)
Ref: http://www.sqlite.org/lang_insert.html