Revisé la lista de características varias veces, y parece que la conexión en cascada debería funcionar. Cuando ejecuta este script en Python:¿Cómo hacer que ON DELETE CASCADE funcione en sqlite 3.7.4?
#!/usr/bin/env python3
import sqlite3
print(sqlite3.sqlite_version)
con = sqlite3.connect(':memory:')
a = "create table a (id integer primary key, name text)"
con.execute(a)
b = "create table b (id integer primary key, r integer, foreign key(r) references a(id) on delete cascade)"
con.execute(b)
con.commit()
a = "insert into a (name) values (\"abc\")"
con.execute(a)
con.commit()
print(con.execute("select * from a").fetchall())
a = "insert into b (r) values (1)"
con.execute(a)
con.commit()
print(con.execute("select * from b").fetchall())
a = "delete from a where id=1"
con.execute(a)
con.commit()
print(con.execute("select * from b").fetchall())
print(con.execute("select * from a").fetchall())
puedo obtener estos resultados:
3.7.4
[(1, 'abc')]
[(1, 1)]
[(1, 1)]
[]
lo que demuestra que en cascada no sucedió. ¿Qué hice mal o cuáles son las soluciones para obtener el mismo resultado que en cascada?
Aunque me quité el archivo de base de datos, se quitó todas las migraciones anteriores, y ha creado nuevas migraciones, esta no hizo ninguna diferencia para mí. Las tablas no se crearon con "on delete cascade" como se esperaba. Me pregunto por qué no está sucediendo eso. –