Python sqlite3无法生成表的视图
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Python sqlite3无法生成表的视图,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1243字,纯文字阅读大概需要2分钟。
内容图文
![Python sqlite3无法生成表的视图](/upload/InfoBanner/zyjiaocheng/902/afe07f7b1bd44842817cc6a49d7631b3.jpg)
通过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查询应该成功运行 – 至少它在我的应用程序中运行.
内容总结
以上是互联网集市为您收集整理的Python sqlite3无法生成表的视图全部内容,希望文章能够帮你解决Python sqlite3无法生成表的视图所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。