Qt之SQLite数据库的使用(2)

    驱动层为具体的数据库和SQL接口层之间提供了底层的桥梁,主要类包括Qt SQL模块中的QSqlDriver、QSqlDriverCreator、QSqlDriverCreatorBase、QSqlDriverPlugin和QSqlResult。

一、QSqlDriver

QSqlDriver是访问具体SQL数据库的抽象基类,不能直接使用。如果要创建自定义的数据库驱动,可以根据需要重写QSqlDriver类的纯虚函数和虚函数。

自定义数据库驱动

QSqlDatabase负责加载和管理数据库驱动插件。当某个数据库添加时,相应的数据库驱动插件会被加载。QSqlDatabase依靠驱动插件为QSqlDriver和QSqlResult提供接口。

QSqlDriver是定义了SQL数据库功能的抽象基类。

二、QSqlDriverCreator

    QSqlDriverCreator是为指定驱动类型提供SQL驱动工厂的模板类。QSqlDriverCreator<T>实例化对象的类型T就是QSqlDriver的子类。

[virtual] QSqlDriver *QSqlDriverCreator::createObject() const

    对QSqlDriverCreatorBase::createObject()函数的重写

三、QSqlDriverCreatorBase

QSqlDriverCreatorBase是SQL驱动工厂的基类。

[pure virtual] QSqlDriver *QSqlDriverCreatorBase::createObject() const

    重写这个函数返回一个QSqlDriver子类的实例

四、QSqlDriverPlugin

    QSqlDriverPlugin类提供自定义QSqlDriver插件的抽象基类。

    SQL数据库驱动插件是一个能被QT动态加载的自定义SQL数据库驱动插件创建变得容易的简单插件接口。

    写SQL插件可以通过派生QSqlDriverPlugin类实现,重写纯虚函数create(),使用宏Q_PLUGIN_METADATA()导出类。

pure virtual] QSqlDriver *QSqlDriverPlugin::create(const QString &key)

    创建并返回一个驱动名为key的QSqlDriver对象

五、QSqlResult

    QSqlResult类提供了访问具体SQL数据库数据的抽象接口。

    通常会使用QSqlQuery代替QSqlResult,因为QSqlQuery提供了具体数据库的QSqlResult实现的通用包装。

    如果通过派生QSqlDriver实现自定义SQL驱动,需要提供实现了全部纯虚函数和需要的虚函数的自定义的QSqlResult子类。

[protected] QSqlResult::QSqlResult(const QSqlDriver *db)

    使用数据库驱动db构建一个QSqlResult对象


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值