Qt数据库驱动层

Qt的QSqlDriver类是数据库访问的抽象基类,用于创建特定数据库的接口。QSqlDatabase管理数据库驱动插件,加载和管理数据库。QSqlResult提供访问数据库数据的接口,通常使用QSqlQuery进行操作。QSqlDriverCreator和QSqlDriverPlugin则涉及自定义数据库驱动的创建和加载。
摘要由CSDN通过智能技术生成

1. Qt驱动层

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

2. QSqlDriver

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

该类不能直接使用,如果要使用使用QSqlDatabase代替。

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

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

本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

公有成员方法

QSqlDriver(QObject *parent = nullptr)
virtual	~QSqlDriver()
virtual bool	beginTransaction()
virtual void	close() = 0
virtual bool	commitTransaction()
virtual QSqlResult *	createResult() const = 0
virtual QString	escapeIdentifier(const QString &identifier, QSqlDriver::IdentifierType type) const
virtual QString	formatValue(const QSqlField &field, bool trimStrings = false) const
virtual QVariant	handle() const
virtual bool	hasFeature(QSqlDriver::DriverFeature feature) const = 0
virtual bool	isIdentifierEscaped(const QString &identifier, QSqlDriver::IdentifierType type) const
virtual bool	isOpen() const
bool	isOpenError() const
QSqlError	lastError() const
QSql::NumericalPrecisionPolicy	numericalPrecisionPolicy() const
virtual bool	open(const QString &db, const QString &user = QString(), const QString &password = QString(), 
const QString &host = QString(), int port = -1, const QString &options = QString()) = 0
virtual QSqlIndex	primaryIndex(const QString &tableName) const
virtual QSqlRecord	record(const QString &tableName) const
virtual bool	rollbackTransaction()
void	setNumericalPrecisionPolicy(QSql::NumericalPrecisionPolicy precisionPolicy)
virtual QString	sqlStatement(QSqlDriver::StatementType type, const QString &tableName, const QSqlRecord &rec, 
bool preparedStatement) const
virtual QString	stripDelimiters(const QString &identifier, QSqlDriver::IdentifierType type) const
virtual bool	subscribeToNotification(const QString &name)
virtual QStringList	subscribedToNotifications() const
virtual QStringList	tables(QSql::TableType tableType) const
virtual bool	unsubscribeFromNotification(const QString &name)

3. QSqlDriverCreator

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

成员方法:

[override virtual] QSqlDriver *QSqlDriverCreator::createObject() const
Reimplemented from QSqlDriverCreatorBase::createObject(). 

4. QSqlDriverCreatorBase

QSqlDriverCreatorBase是SQL驱动工厂的基类。

重新实现createObject()以返回要提供的特定QSqlDriver子类的实例。

成员方法:

virtual ~QSqlDriverCreatorBase()
virtual QSqlDriver *createObject() const = 0

5. QSqlDriverPlugin

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

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

写SQL插件可

QSqlDriverPlugin(QObject *parent = nullptr)
virtual ~QSqlDriverPlugin()
virtual QSqlDriver *create(const QString &key) = 0

6. QSqlResult

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

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

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

成员方法:

QSqlResult(const QSqlDriver *db)
void	addBindValue(const QVariant &val, QSql::ParamType paramType)
int	at() const
virtual void	bindValue(int index, const QVariant &val, QSql::ParamType paramType)
virtual void	bindValue(const QString &placeholder, const QVariant &val, QSql::ParamType paramType)
QSql::ParamType	bindValueType(int index) const
QSql::ParamType	bindValueType(const QString &placeholder) const
QSqlResult::BindingSyntax	bindingSyntax() const
QVariant	boundValue(int index) const
QVariant	boundValue(const QString &placeholder) const
int	boundValueCount() const
QString	boundValueName(int index) const
QVector<QVariant> &	boundValues() const
void	clear()
virtual QVariant	data(int index) = 0
const QSqlDriver *	driver() const
virtual bool	exec()
QString	executedQuery() const
virtual bool	fetch(int index) = 0
virtual bool	fetchFirst() = 0
virtual bool	fetchLast() = 0
virtual bool	fetchNext()
virtual bool	fetchPrevious()
bool	hasOutValues() const
bool	isActive() const
bool	isForwardOnly() const
virtual bool	isNull(int index) = 0
bool	isSelect() const
bool	isValid() const
QSqlError	lastError() const
virtual QVariant	lastInsertId() const
QString	lastQuery() const
virtual int	numRowsAffected() = 0
virtual bool	prepare(const QString &query)
virtual QSqlRecord	record() const
virtual bool	reset(const QString &query) = 0
void	resetBindCount()
virtual bool	savePrepare(const QString &query)
virtual void	setActive(bool active)
virtual void	setAt(int index)
virtual void	setForwardOnly(bool forward)
virtual void	setLastError(const QSqlError &error)
virtual void	setQuery(const QString &query)
virtual void	setSelect(bool select)
virtual int	size() = 0

本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值