sqlite 无法创建视图的视图

mzsu5hc0  于 2022-11-24  发布在  SQLite
关注(0)|答案(2)|浏览(185)

我尝试使用Python访问视图的视图:

import sqlite3

conn = sqlite3.connect("test.db")
mydb = conn.cursor()

mydb.execute("CREATE TABLE TestTbl (MRTarget_id int, Fullmodel text)")
mydb.execute("CREATE TABLE TestTbl2 (Other_id int, Othermodel text)")

mydb.execute("CREATE VIEW TestView AS SELECT m.ROWID, m.MRTarget_id, m.Fullmodel, t.Othermodel FROM TestTbl m, TestTbl2 t")
mydb.execute("CREATE VIEW TestView2 AS SELECT m.Fullmodel, m.Othermodel FROM TestView m")

mydb.close()

尝试创建TestView2时,出现错误:
sqlite3.OperationalError:无此列:m.Fullmodel
上面的SQL语句在SQLite提示下运行良好。数据库包含视图的视图;是否不可能使用Python访问这些内容?

nuypyhwy

nuypyhwy1#

我也遇到过同样的问题--我找到了一个解决方案。我相信你的问题是在你的初始视图'TestView'中,属性名称实际上是m.ROWIDm.Fullmodel等,而不是ROWIDFullmodel等。
通过sqlite管理器随意查看视图不会显示附加到每个字段名前面的m.。如果运行Pragma查询PRAGMA table_info TestView,则会显示属性扩展。
因此,将TestView创建查询更改为

CREATE VIEW TestView AS 
SELECT m.ROWID as ROWID, m.MRTarget_id as MRTarget_id,... etc

第二个Create View查询应该成功运行--至少在我应用程序中是这样。

smdnsysy

smdnsysy2#

你的代码对我来说很好用。
您可以尝试在创建第一个视图和第二个视图之间进行提交:

conn.commit()

相关问题