SQLite,是一款轻型的数据库,是遵守ACID的关联式,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。下面简单介绍下pyqt连接sqlite数据库的方法:
- #-*- coding: utf-8 -*-
- from PyQt4.QtGui import *
- from PyQt4.QtCore import *
- from PyQt4.QtSql import *
- import sys
- #创建数据库连接
- def createConnection():
- #选择数据库类型,这里为sqlite3数据库
- db=QSqlDatabase.addDatabase("QSQLITE")
- #创建数据库test0.db,如果存在则打开,否则创建该数据库
- db.setDatabaseName("test0.db")
- #打开数据库
- db.open()
- #创建表
- def createTable():
- #创建QsqlQuery对象,用于执行sql语句
- q=QSqlQuery()
- q.exec_("create table if not exists t1 (f1 integer primary key,f2 varchar(20))")
- q.exec_("delete from t1")
- #这里使用 u 将字符串转换成unicode编码,解决中文乱码
- q.exec_(u"insert into t1 values(1,'我')")
- q.exec_(u"insert into t1 values(2,'我')")
- q.exec_("commit")
- class Model(QSqlTableModel):
- def __init__(self,parent):
- QSqlTableModel.__init__(self,parent)
- #设置要载入的表名
- self.setTable("t1")
- #这一步应该是执行查询的操作,不太理解
- self.select()
- #数据更新的策略,详细可以查看Qt文档
- self.setEditStrategy(QSqlTableModel.OnManualSubmit)
- class TestWidget(QWidget):
- def __init__(self):
- QWidget.__init__(self)
- vbox=QVBoxLayout(self)
- self.view=QTableView()
- self.model=Model(self.view)
- self.view.setModel(self.model)
- vbox.addWidget(self.view)
- if __name__=="__main__":
- a=QApplication(sys.argv)
- createConnection()
- createTable()
- w=TestWidget()
- w.show()
- sys.exit(a.exec_())
阅读(5553) | 评论(1) | 转发(0) |