加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

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查询应该成功运行 – 至少它在我的应用程序中运行.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读