Does SQLite support referential integrity?
Asked Answered
D

1

9

I have a Django web-server configured to use SQLite.

In a many-to-many relationship (with extra fields), Django forces me to use the relationship model to establish a relationship between two objects. But I'm able to create a relationship between objects, that don't yet exist in the related tables.

For e.g:

I have table1 and table2 which are related via table12.
In table1, there is just one object called A.
In table2, there is just one object called X.
I can create a record in table12 that depict a relationship between A & Y; even though Y doesn't exist in table2.

My relationship model has marked the foreign keys appropriately.

Dorsoventral answered 20/6, 2013 at 12:17 Comment(0)
J
17

SQLite does not enforce foreign key constraints by default (mostly to be backward compatible).

To enable it, you have to execute

PRAGMA foreign_keys = 1

after you connected to the database.

See the manual about PRAGMA foreign_keys for more details.

Janeljanela answered 20/6, 2013 at 12:31 Comment(2)
Also found a way to enable it in Django! #6746263Dorsoventral
A slightly nicer variant would be PRAGMA foreign_keys=ON rather than 1Contradance

© 2022 - 2024 — McMap. All rights reserved.