LabVIEW实现Oracle数据库的访问(深入浅出labview数据库应用)
wptr33 2025-07-24 22:32 29 浏览
1. 安装 Oracle 客户端
- 下载:从 Oracle 官方网站下载适用于 Windows 操作系统的 Oracle 驱动程序。确保下载的版本与 LabVIEW 环境和操作系统兼容。
1)以 Windows 7 64 位操作系统和 32 位 LabVIEW 为例,首先访问官网 Oracle Instant Client 下载地址(
https://www.oracle.com/database/technologies/instant-client/downloads.html),打开下图所示界面,点击“Instant Client for Microsoft Windows (32-bit)”,进入Oracle Instant Client即时客户端版本选择界面。
2)选择适配 Windows 7 系统的版本,实测可选“Version 11.2.0.4.0”,点击右侧的“+”,展开具体的下载选项。
3)因为打算 LabVIEW 使用 ODBC 驱动方式去访问 Oracle 数据库,需要下载 2 个应用程序包,即 “
instantclient-basic-nt-11.2.0.4.0.zip” 和 “
instantclient-odbc-nt-11.2.0.4.0.zip” 。
- 安装:
1)将下载好的 “
instantclient-basic-nt-11.2.0.4.0.zip” 和 “
instantclient-odbc-nt-11.2.0.4.0.zip” 压缩文件解压缩到同一个文件夹中,解压后如下图所示。
2)以管理员方式运行解压后的 “odbc_install.exe” ,安装Oracle odbc驱动支持。
3)在解压后的文件夹中创建文件夹 “network” ,并在 “network” 下创建 “admin” 子文件夹,并在 “admin” 子文件夹中创建一个名为 “tnsnames.ora” 的文件。(在 Oracle 网络环境中,客户端需要知道如何连接到特定的数据库服务器,“tnsnames.ora” 文件就像是一个地址簿,存储了网络服务名与数据库服务器的连接描述符之间的映射关系,客户端在发起连接请求时,会通过指定网络服务名,然后依据该文件中的配置信息找到对应的数据库服务器地址、端口、服务名等,从而建立起连接。)
4)在 “tnsnames.ora” 文件中写入以下内容:
TESTLINK=
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 10.96.88.120)(PORT = 1527))
)
(CONNECT_DATA =
(SERVICE_NAME = TESTDATA)
)
)其中,10.96.88.120要根据实际情况改为自己需要连接的远程服务器的地址,TESTDATA是数据库实例的名称。
5)配置系统环境变量
需要配置2个系统环境变量,分别如下图所示。
2. 配置 ODBC 数据源
- 打开 ODBC 数据源管理器:在 Windows 系统中,可以通过控制面板找到 “管理工具”,然后打开 “ODBC 数据源(64 位)” 或 “ODBC 数据源(32 位)”(根据 LabVIEW 版本是 32 位还是 64 位来选择 )。
以 32 位 LabVIEW 为例,先在 “C:\Windows\SysWOW64” 路径下找到 “odbcad32.exe”,以管理员方式将其打开。
打开后的界面如下图所示。
- 添加数据源:点击 “添加” 按钮,选择 Oracle 的 ODBC 驱动程序(通常是 Oracle in instantclient_XX_X,XX_X代表版本号 ),然后点击 “完成”。
此处选择 “Oracle in instantclient_11_2” 驱动程序。
- 配置数据源信息:在弹出的配置窗口中,输入Data Source Name(可自定义,比如 “TestDatabase” )、Description(可选 )、下拉选择TNS Service Name(在tnsnames.ora中配置的服务名)、User ID,点击Test Connection。
在弹出的 “Oracle ODBC Driver Connect” 对话框中输入有效的用户名和密码,点击“OK”按钮进行测试连接,若配置正确且服务器数据库可连接,则会弹出“Test Success”提示框。
3. 在 LabVIEW 中创建数据库连接
- 打开 LabVIEW,点击“工具”→“Create Data Link...”,将弹出数据库链接对话框。
- 选择数据库驱动程序:在提供程序页面,选择 “Microsoft OLE DB Provider for ODBC Drivers” ,点击下一页。
- 配置数据库连接:在“连接”页面,在“指定数据源”条款,选择“使用数据源名称”,并下拉选择之前配置的数据源名称“TestDatabase”,输入用户名称和密码后,可以点击“测试连接”,若配置正确且服务器数据库可连接,则会弹出“Test Success”提示框。
- 保存udl:测试连接成功后点击“确定”按钮,弹出保存udl文件对话框,选择保存路径和填入保存文件名后,保存udl文件。udl文件中存储的是LabVIEW与Oracle数据库连接的字符串信息,通过该字符串即可实现与Oracle数据库的连接。
- 在LabVIEW中与数据库建立连接:将udl文件中的数据库连接字符串连接到 “DB Tools Open Connection.vi” 函数的 “Connection Information” 输入端口,然后运行 VI,成功连接后会返回一个连接句柄。
通过以上配置,就可以在 LabVIEW 中实现对 Oracle 数据库的访问,进行数据的查询、插入、更新和删除等操作了。
相关推荐
- oracle数据导入导出_oracle数据导入导出工具
-
关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...
- 继续学习Python中的while true/break语句
-
上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个else解...
- python continue和break的区别_python中break语句和continue语句的区别
-
python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...
- 简单学Python——关键字6——break和continue
-
Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...
- 2-1,0基础学Python之 break退出循环、 continue继续循环 多重循
-
用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...
- Python 中 break 和 continue 傻傻分不清
-
大家好啊,我是大田。今天分享一下break和continue在代码中的执行效果是什么,进一步区分出二者的区别。一、continue例1:当小明3岁时不打印年龄,其余年龄正常循环打印。可以看...
- python中的流程控制语句:continue、break 和 return使用方法
-
Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...
- L017:continue和break - 教程文案
-
continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...
- 作为前端开发者,你都经历过怎样的面试?
-
已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...
- 面试被问 const 是否不可变?这样回答才显功底
-
作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...
- 2023金九银十必看前端面试题!2w字精品!
-
导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。答案:CSS的盒模型是用于布局和定位元素的概念。它由内容区域...
- 前端面试总结_前端面试题整理
-
记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...
- 由浅入深,66条JavaScript面试知识点(七)
-
作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录由浅入深,66条JavaScript面试知识点(一)由浅入深,66...
- 2024前端面试真题之—VUE篇_前端面试题vue2020及答案
-
添加图片注释,不超过140字(可选)1.vue的生命周期有哪些及每个生命周期做了什么?beforeCreate是newVue()之后触发的第一个钩子,在当前阶段data、methods、com...
- 今年最常见的前端面试题,你会做几道?
-
在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...
- 一周热门
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)
