Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Does SQLite support referential integrity?

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.

like image 962
mynk Avatar asked Jun 20 '13 12:06

mynk


1 Answers

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.

like image 96
Johannes Kuhn Avatar answered Sep 24 '22 17:09

Johannes Kuhn