QSqlDatabase的数据库路径或名称问题

在Qt的数据库编程中,先是设置数据库的类型,然后是设置数据库文件的路径,或者数据库名称。若有数据库的用户名、密码,则分别调用setUserName("")、setPassword("")来设置用户名和密码;若没有,则省略用户名和密码。

  • 通过QSqlDatabase::addDatabase("")来设置数据库的类型;
  • 通过setDatabaseName("")来设置数据库的文件路径,或者数据库名称。

这个setDatabaseName("xxx.db")函数,对路径的依赖比较敏感。在Windows平台上,需要将路径的分割符号斜杠,要写成2个//斜杠。

1 SQLite类型

正常代码:

cpp 复制代码
	QSqlDatabase dbData = QSqlDatabase::addDatabase("QSQLITE","UID1000");
	//数据库路径
	QString strPath = QCoreApplication::applicationDirPath() + "//hello.db";
	dbData.setDatabaseName(strPath);	

注意在Windows平台上,若setDatabaseName("Path")里的Path是文件路径,则要写成双斜杠的形式;若写成单斜杠,会造成数据库可以打开,但无法查询,也无法插入的异常问题。

异常代码:

cpp 复制代码
	QSqlDatabase dbData = QSqlDatabase::addDatabase("QSQLITE","UID1000");
	//单斜杠,在Windows平台上,会造成数据库可以连接,但无法查询表中数据的Bug
	QString strPath = "D:/myDatabase/hello.db";
	dbData.setDatabaseName(strPath);

2 SQL Server类型

若SQL Server是以ODBC的方式与Qt程序进行连接,则setDatabaseName("")里要填写数据库的名称。

cpp 复制代码
    QSqlDatabase dbData = QSqlDatabase::addDatabase("QODBC");
    dbData.setHostName("127.0.0.1");
    dbData.setDatabaseName("hello");  //数据库名称
    dbData.setUserName("user");
    dbData.setPassword("xxx");
相关推荐
D***44142 分钟前
【Mysql】:如何配置最大连接数?
数据库·mysql
q***16083 分钟前
MySQL的底层原理与架构
数据库·mysql·架构
8***f3955 分钟前
【零基础学Mysql】常用函数讲解,提升数据操作效率的利器
数据库·mysql
这人很懒没留下什么8 分钟前
SpringBoot2.7.4整合MongoDb
数据库·spring boot·mongodb
0***v7779 分钟前
redis批量删除namespace下的数据
数据库·redis·缓存
q***062910 分钟前
【细如狗】记录一次使用MySQL的Binlog进行数据回滚的完整流程
android·数据库·mysql
8***848211 分钟前
SQL 实战—递归 SQL:层级结构查询与处理树形数据
java·数据库·sql
睡前要喝豆奶粉14 分钟前
EF Core动态sql
数据库·sql·c#·.netcore
p***s9116 分钟前
mysql用户名怎么看
数据库·mysql
5***g22918 分钟前
Ubuntu 系统下安装 Nginx
数据库·nginx·ubuntu