Python sqlite3无法生成表的视图
发布时间:2020-12-20 13:25:37 所属栏目:Python 来源:网络整理
导读:通过 python我打开一个SQLite数据库,并尝试访问一个表的视图.不幸的是我收到了错误消息.下面的 Python代码演示了这个问题: import sqlite3conn = sqlite3.connect("test.db")mydb = conn.cursor()mydb.execute("CREATE TABLE TestTbl (MRTarget_id int,Full
通过
python我打开一个SQLite数据库,并尝试访问一个表的视图.不幸的是我收到了错误消息.下面的
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之后,Python吐出错误“sqlite3.OperationalError:no such column:m.Fullmodel”.但是,从Sqlite3提示符可以执行上述SQL语句而没有任何问题.由于我的数据库包含表视图的视图,我想知道是否完全不可能通过Python以编程方式访问它们. 解决方法
我遇到了同样的问题 – 我找到了解决方案.我相信你的问题是在初始视图’TestView’中,属性名称实际上是m.ROWID,m.Fullmodel等,而不仅仅是ROWID,Fullmodel等.
通过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查询应该成功运行 – 至少它在我的应用程序中运行. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |