Qt访问odbc(access)遇到的问题

背景:

我做了一个简单的库,负责与数据库交互,希望能兼容数据库类型多一些。偶然想试试access,结果调试出错了。特此记录下来。

原因:

windows中的odbc中,预制了很多基础的数据库驱动,这在2000年上大学时,做项目就研究过。

所谓驱动,无非就是一些dll,和注册表键值指向。如果要自己做个安装程序去部署客户机,对照本机开发环境,去设置注册表和复制dll即可。亲测没问题,这就是windows的机制。

qt针对odbc是统一处理的,它算一种单独的连接类型。databasename设置为odbc的dsn字符串即可。就如这样:

DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};FIL={MS Access};DBQ=access.mdb;Uid=;Pwd=;
 

这个串也可以用技巧自动生成的,具体忘了,大概是新建一个什么扩展名的文件,双击运行后打开odbc数据源设置界面,设置好以后,再次用记事本打开这个文件,就看到dsn字符串了。

可以先新建一个.dsn文件(文件数据源),设置好以后用记事本打开,各种属性一览无余,然后分号分割也可以拼出连接字符串。

调试出错原因在于,现在的windows内置的odbc是32位和64位两种版本,很多驱动是32位的,亦即,在32位odbc管理器中可以看到,而64位的odbc管理器中就没有。所以如果你的程序是64位的,它连接数据库时,想调用的驱动dll是32位的,就不行。

而且还有一点要注意,dsn字符串中指定的driver,必须和odbc管理器中看到的一模一样。比如access串中的驱动,是{Microsoft Access Driver (*.mdb, *.accdb)}还是{Microsoft Access Driver (*.mdb)}?一定不能错。

结论:

时代是要发展的,很多老技术默认是被淘汰的,如果真的遇到问题了,可以多一种解决思路。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/761947.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

工控机在机器人领域的应用丨工业一体机的应用

随着机器人技术的不断发展,机器人在制造、物流等领域得到了广泛应用。而工业控制计算机(工控机)作为机器人控制系统的核心设备,也在机器人领域发挥着越来越重要的作用。 机器人控制系统是机器人的核心部分,控制系统的…

综合知识篇15-开发管理考点(2024年软考高级系统架构设计师冲刺知识点总结系列文章)

专栏系列文章: 2024高级系统架构设计师备考资料(高频考点&真题&经验)https://blog.csdn.net/seeker1994/category_12593400.html案例分析篇00-【历年案例分析真题考点汇总】与【专栏文章案例分析高频考点目录】(2024年软考高级系统架构设计师冲刺知识点总结-案例…

仅用一个月,游卡完成从MySQL到上线OceanBase的实践

编者按:自2023年9月起,游卡——国内最早卡牌游戏研发者之一,开始测试OceanBase,并在短短两个月内成功将三个核心业务应用迁移至OceanBase上。究竟是何因素促使游卡放弃游戏行业普遍采用的MySQL方案,转而大胆选择OceanB…

Spring Colud Alibaba: Spring Cloud Alibaba 是什么

文章目录 一、介绍二、特征 一、介绍 Spring Cloud Alibaba 是 Spring Cloud 的一个子项目,它基于阿里巴巴的开源技术和产品,为开发者提供了一套微服务解决方案。Spring Cloud Alibaba 提供了一系列的微服务开发工具,帮助开发者构建分布式应…

国内ip切换是否合规?

在网络使用中,IP地址切换是一种常见的行为,可以用于实现隐私保护、访问地域限制内容等目的。然而,对于国内用户来说,IP地址切换是否合规一直是一个备受关注的话题。在中国,网络管理严格,一些IP切换行为可能…

Java安全 反序列化(3) CC1链-TransformedMap版

Java安全 反序列化(3) CC1链-TransformedMap版 本文尝试从CC1的挖掘思路出发,理解CC1的实现原理 文章目录 Java安全 反序列化(3) CC1链-TransformedMap版配置jdk版本和源代码配置前记 为什么可以利用一.CC链中的命令执行我们可以尝试一下通过InvokerTransformer.tr…

day24| 77.组合 51. N Queens 78.Subsets 79.Word Search 开启岛屿系列以及贪心!

77. 不重复不复选 class Solution { public:vector<vector<int>> results;vector<int> cur;void backtrack(int n,int k,int level){if(cur.size()>k){results.push_back(cur);return;}for(int i level;i<n;i){cur.push_back(i);backtrack(n,k,i1);…

ssm项目(tomcat项目),定时任务(每天运行一次)相同时间多次重复运行job 的bug

目录标题 一、原因 一、原因 debug本地调试没有出现定时任务多次运行的bug&#xff0c;上传到服务器就出现多次运行的bug。&#xff08;war的方式部署到tomcat&#xff09; 一开始我以为是代码原因&#xff0c;或者是linux和win环境不同运行定时任务的方式不一样。 但是自己…

专业135+总分400+重庆邮电大学801信号与系统考研经验重邮电子信息与通信工程,真题,大纲,参考书。

今年分数出来还是比较满意&#xff0c;专业801信号与系统135&#xff0c;总分400&#xff0c;没想到自己也可以考出400以上的分数&#xff0c;一年的努力付出都是值得的&#xff0c;总结一下自己的复习心得&#xff0c;希望对大家复习有所帮助。专业课&#xff1a;&#xff08;…

获取KEGG通路的基因列表 做单细胞GSEA、GSVA分析

使用KEGG通路的基因列表进行单细胞GSEA GSVA分析的过程&#xff0c;我们需要遵循以下步骤&#xff1a; 获取KEGG通路的基因列表&#xff1a;这通常涉及使用专门的R包&#xff0c;如KEGGREST或biomaRt&#xff0c;来查询KEGG数据库并检索特定通路的基因列表。 准备单细胞表达数…

HTML与Logic java基础面试题

序号问题答案21给定一个已经排序好了的数组要在数组中查找某个元素一般使用什么算法二分查找法22java八种基本数据类型 byte,short,int,long,float,double,char,boolean23编码实现一个数组的冒泡排序int nums[] {5,99,100,44,66,20} for(int i0;i<nums.length-1;i){ for…

【设计模式】Java 设计模式之责任链模式(Chain of Responsibility)

责任链模式&#xff08;Chain of Responsibility&#xff09; 一、概述 责任链模式是一种行为设计模式&#xff0c;它允许请求在对象链中传递。每个对象都有机会处理该请求&#xff0c;并且能将其传递给链中的下一个对象。这种模式为请求创建了一个处理对象的链&#xff0c;并…

申请Github Education获取免费Copilot权限(2024.3.18实测成功)

起因&#xff1a;旧帐户Copilot权限被封 我已经离开Github Copilot就无法独自耐着性子写代码了&#xff08;懒惰AI成瘾性&#xff09;&#xff0c;这两天Github Copilot不知道为什么在大规模封号&#xff0c;我不幸也被封号了&#xff08;禁用掉了Github Copilot权限&#xff…

Python:柱状-折线图

写论文&#xff0c;需要画数据分析图&#xff1a; 用柱状图描述算法执行时间用折线图描述性能改进 示例代码&#xff1a; import numpy as np import matplotlib.pyplot as plt from matplotlib.pyplot import MultipleLocatorSecurity ["128", "192",…

RPC浅析,加密数据解析

个人总结 其实就是HOOK注入wbsocket 链接创建服务端和客户端进行通信&#xff0c;直接调用js代码中的加密方法 将结果通过浏览器客户端传入服务端。一种比较好实用的一种技术 https://blog.csdn.net/qq_36759224/article/details/123082574 &#xff08;搬运记录下&#xff…

Linux第82步_“gpio子系统”下的使用KEY开关灯

使用新字符设备驱动的一般模板和“gpio子系统”&#xff0c;以及设备树&#xff0c;驱动KEY和LED。 1、在stm32mp157d-atk.dts文件中添加“gpio_led”和“key0”节点 打开虚拟机上“VSCode”&#xff0c;点击“文件”&#xff0c;点击“打开文件夹”&#xff0c;点击“zgq”&…

HTTPS 协议原理

目录 HTTPS VS HTTP HTTPS是什么 概念准备 常见的加密方式 对称加密 一个简单的对称加密例子 非对称加密 数据摘要&&数据指纹 数字签名 HTTPS 的工作过程探究 方案1-只使用对称加密 方案2-只使用非对称加密 方案3-双方都使用非对称加密 方案4-非对称加密…

Cell发表的单细胞整合方法:LIGER,很好用!

之前&#xff0c;我们已经介绍过其他的整合方法&#xff1a; harmony整合单细胞数据-去除批次效应 Seurat一键完成五种数据整合&#xff1a;harmony&#xff0c;CCA&#xff0c;RPCA,FastMNN,scVI&#xff0c;代码分享 今天来看看Cell发表的LIGER 介绍 LIGER&#xff08;Li…

C++语言学习(二)—— C++语言的基本知识

目录 一、面向对象的三个核心概念 二、C语言中的I/O口 三、C语言中的数据类型​​​​​​​ 3.1 逻辑类型 3.2 引用类型 3.2.1 引用作为函数参数 3.2.2 引用作为函数返回值 3.2.3 引用作为类成员 3.3 类类型 四、 C语言中的内联函数 五、 函数重载 六、 带默认形参…

docker 容器挂掉,无法exec 进入bash 怎么修改容器里的文件

在使用tdengine 数据库时出现了 TDengine.Driver.TDengineError:“code:[0x334],error:Out of dnodes” 查找文档发现需要修改一个配置文件 。 /etc/taos/taos.cfg 中的 supportVnodes 参数 于是修改 保存。然后&#xff0c;运行出错。 03/21 06:56:27.986498 00000064 …