ODBC的基本使用

news2025/2/24 7:33:58

前言

       在工作中,使用POWERBI做数据分析报表的时候用到ODBC,对于POWERBI语义模式实现连接数据库必须使用到ODBC,那什么是ODBC?

1.ODBC的基本概念

  1.1ODBC 驱动程序    

  • 每种数据库都有相应的 ODBC 驱动程序,这些驱动程序负责处理与数据库的通信。
  • 驱动程序将 ODBC 调用转换为数据库特定的调用,并将结果返回给应用程序。 

  1.2 数据源名称 (DSN)

  • DSN 是一个配置名称,用于保存连接到数据库所需的信息,如数据库类型、服务器地址、数据库名称、用户凭据等。
  • DSN 可以是用户 DSN(仅当前用户可用)或系统 DSN(系统上所有用户可用)。

   1.3 ODBC 管理工具

  • 用于创建、配置和管理 DSN。用户可以通过 ODBC 管理工具设置新的数据源或修改现有的数据源。

2.ODBC 的工作原理 

  1. 应用程序:应用程序通过 ODBC API 发出数据库请求。
  2. ODBC 驱动管理器:ODBC 驱动管理器负责加载适当的 ODBC 驱动程序,并将应用程序的请求转发给驱动程序。
  3. ODBC 驱动程序:驱动程序将请求转换为特定数据库的协议,并与数据库进行通信。
  4. 数据库:数据库执行请求并返回结果。
  5. 结果返回:ODBC 驱动程序将数据库返回的结果转换为 ODBC 格式,并通过驱动管理器返回给应用程序。

3.ODBC 组件 

   3.1ODBC 驱动管理器

  • 管理 ODBC 驱动程序的加载和卸载。、
  • 提供 API 供应用程序使用。
  • 维护 DSN 配置信息。

   3.2 ODBC 驱动程序

  • 每种数据库都有对应的驱动程序,负责与数据库进行通信。
  • 将 ODBC 函数调用转换为数据库特定的协议。

   3.3  ODBC 数据源

  • 数据源包含数据库连接所需的信息,如服务器名、数据库名、用户 ID 和密码等。

4.ODBC 配置和管理 

       在 Windows 操作系统上,ODBC 数据源管理器用于管理 DSN。以下是配置和管理 DSN 的详细步骤:

    4.1 打开 ODBC 数据源管理器

  • 按 Win + R 打开运行对话框,输入 control panel,然后按 Enter。
  • 在控制面板中,选择“系统和安全”,然后选择“管理工具”。
  • 在管理工具中,找到并双击“ODBC 数据源(64 位)”或“ODBC 数据源(32 位)”,根据您的应用程序是 64 位还是 32 位选择合适的版本。

    4.2创建新的 DSN

  • 在 ODBC 数据源管理器中,选择“用户 DSN”或“系统 DSN”标签页。
  • 点击“添加”按钮,选择要配置的数据库驱动程序(如 SQL Server、MySQL、Oracle 等),然后点击“完成”。

 

    4.3 配置 DSN 

  • 输入数据源名称(DSN 名称)、描述(可选)、服务器名称或 IP 地址、数据库名称。
  • 输入数据库连接所需的凭据(如用户名和密码)。
  • 根据驱动程序的不同,可能需要配置其他选项,如端口号、加密设置等。

 

    4.4测试连接

  • 配置完成后,可以点击“测试连接”按钮,确保可以成功连接到数据库。

5.ODBC的应用场景和优点

    5.1 ODBC 的优点

  • 数据库独立性:应用程序可以使用相同的代码访问不同类型的数据库。
  • 简化开发:开发人员无需为每种数据库编写特定的代码。
  • 灵活性:ODBC 支持各种数据库,包括关系型数据库和非关系型数据库。
  • 可扩展性:可以通过安装新的 ODBC 驱动程序来支持新的数据库。 

    5.2 ODBC 的应用场景

  • 数据集成:将多个不同数据库中的数据整合到一个应用程序中。
  • 数据迁移:在不同数据库系统之间迁移数据。
  • 报告和分析:从不同类型的数据库中提取数据进行报告和分析。

6.示例:配置 SQL Server DSN

  1. 打开 ODBC 数据源管理器
  2. 选择系统 DSN 标签页,点击“添加”。
  3. 选择 SQL Server 驱动程序,点击“完成”。
  4. 输入数据源名称(如  192.168.0.1-qfdb),描述(可选),服务器名称或 IP 地址(如  192.168.0.1),点击“下一步”。
  5. 选择身份验证方式,输入登录凭据(用户名和密码),点击“下一步”。
  6. 选择默认数据库(如 qfdb),点击“下一步”。
  7. 点击完成,然后点击“测试数据源”进行测试连接。
  8. 确认测试成功,然后点击“确定”保存设置。

       ODBC 是一个强大的工具,它提供了一个标准化的方式,使应用程序能够访问各种不同的数据库系统,从而极大地简化了跨数据库的开发和数据集成工作,在工作中常常能够为我们开发人员带来便捷。

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

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

相关文章

系统报错:由于启动计算机时出现了页面文件配置问题,Windows在你的计算机上创建了一个临时页面文件。所有磁盘驱动器的总页面文件大小可能稍大于你所指定的大小

启动电脑时候,突然弹出系统报错的弹窗: 之前由于C盘爆满时候,根据下面教程进行C盘空间清理,感觉是由于清理导致的。 C盘爆满,教你有效清理,释放出几十G的磁盘空间_c盘满了怎么清理c盘空间-CSDN博客文章浏…

前端开发调试工具推荐分类整理

具体前往:前端调试工具分类整理汇总

Windows-安装WSL踩坑

Windows与windows Server 最近在用一台Windows服务器安装linux子系统,在尝试采用常规命令安装Ubun系统时,一直在报错: 正在安装: Ubuntu 安装过程中出现错误。分发名称: ‘Ubuntu’ 错误代码: 0x8000ffff 两个系统存在不同的安装方法&#x…

Docker镜像是如何管理的

Docker镜像管理 rootfs主要特点分层写时复制内容寻址联合挂载 关键概念registryrepositorymanifestimage和layer 镜像构建commit镜像build构建镜像 镜像分发 Docker镜像是一个只读的容器模板,含有启动Docker容器所需的文件系统结构及其内容,因此是启动一…

【Linux】一些基本指令

文章目录 前言Linux下基本指令Linux下一些常见的通配符Linux下的引号引用whoamiwholswhichaliaswhereisfindtouchmkdirrmdir & rmmancpmvcatmorelessheadtailechodatecalgrepzip & unziptarrz & szuname几个重要的热键关机 前言 在学习操作系统的时候,我…

甲方产品过于平庸该如何编写策划案?

面对甲方产品相对平庸的情况,作为策展新人,你需要发挥创意和策略思维,通过巧妙的策划来挖掘和呈现产品的独特价值,让观众在展馆中依然能找到吸引他们的亮点。 以下是一些建议,希望能帮助你编写出既真实又能吸引眼球的…

linux root登陆,密码正确但,错误提示su: Authentication failure

初开始登陆的时候会显示失败,参考了很多网上的做法,但还是不行,但是,如果用键盘左边那一排数字按键输入,就可以正常登陆(之前用的是右边的九宫格)

学前教育优化算法,原理详解,MATLAB代码免费获取

学前教育优化算法(Preschool Education Optimization Algorithm,PEOA)是一种受学前教育过程中孩童的活动行为启发而提出的元启发式优化算法。学前教育在儿童的早期发展中起着至关重要的作用,并为他们未来的学习旅程奠定基础。作为幼儿学习者发…

C# datetimePicker

1. 直接把控件拉到设计器中,此时不要调整控件的values属性,这样就可以 打开后每次默认显示当天日期。 2. 属性Format long长日期格式默认值short短日期格式Time时间格式custom自定义时间格式在customFormat这个属性设置,比如yyyy-MM-dd HH…

图中的最短环

2608. 图中的最短环 现有一个含 n 个顶点的 双向 图,每个顶点按从 0 到 n - 1 标记。图中的边由二维整数数组 edges 表示,其中 edges[i] [ui, vi] 表示顶点 ui 和 vi 之间存在一条边。每对顶点最多通过一条边连接,并且不存在与自身相连的顶…

入门 PyQt6 看过来(案例)11~ 熊猫展览馆

主题:利用pyqt6实现一个展示萌兰、福宝、金虎等大熊猫的展示案例。 1 界面布局 本案例用到了列表的功能 #定义列表listModelQStringListModel()#列表数据self.list[福宝,萌兰,金虎]#将列表转换列表模式listModel.setStringList(self.list)#列表展示listViewQListVi…

日拱一卒 | JVM

文章目录 什么是JVM?JVM的组成JVM的大致工作流程JVM的内存模型 什么是JVM? 我们知道Java面试,只要你的简历上写了了解JVM,那么你就必然会被问到以下问题: 什么是JVM?简单说一下JVM的内存模型?…

Python中的zip

一、什么是zip()? zip()函数接受任意数量的可迭代对象作为参数,并返回一个迭代器。这个迭代器生成的元素是元组,每个元组包含所有输入可迭代对象中对应位置的元素。 二、基本用法 假设我们有两个列表,一个是学生的名字&#xf…

windows10配置英文输入法的方法

📑打牌 : da pai ge的个人主页 🌤️个人专栏 : da pai ge的博客专栏 ☁️宝剑锋从磨砺出,梅花香自苦寒来 ☁️运维工程师的职责:监…

将TP5链接导入笔影个人博客代码

首先第一步,打开界面 第二步,这里卡住了,无法看到源代码,我们使用其他软件看看源代码 调试乱码,因为没有找到相应的笔影个人博客源码。源码在桌面上。询问百度,说了有的没的一大堆。 尝试的结果就是失败…

Amesim中在现有的元件调出其内部参数使其作为输出进行调用

前言 在实际项目工程应用中,有时需要调用一些元件内部的参数进行应用来实现控制。例如调用电池元件的欧姆内阻计算电池的欧姆产热。 操作案例 例如:车前散热模块,需要调用外部风量参数来控制风机的转速。方法如下: 子模型模块下→选中元件右键→选择sense internal var…

人机环境系统智能的典型特性

人机环境系统智能的典型特性包括:感知与感知能力。智能系统具有感知外界环境的能力,可以通过各种传感器获取数据,如视觉、声音、温度、湿度等信息。这些感知能力使系统能够实时了解环境状态和变化。学习与适应能力。智能系统可以通过学习算法…

C++《类和对象》(中)

一、 类的默认成员函数介绍二、构造函数 构造函数名与类同名内置类型与自定义类型析构函数拷贝构造函数 C《类和对象》(中) 一、 类的默认成员函数介绍 默认成员函数就是⽤⼾没有显式实现,编译器会⾃动⽣成的成员函数称为默认成员函数。 那么我们主要学习的是1&…

2007-2022年 上市公司-创新投入、研发投入数据(原始数据、do文件、参考文献、data等文件)

创新投入是企业通过不断改进和引入新产品来满足市场需求,并以此获得市场竞争优势的关键过程。而研发投入则是企业为推动产品创新所进行的资源投资,涵盖了人力、物力和财力等多个方面。 数据概览 本数据集提供了关于上市公司创新与研发投入的详细观测值…

抽奖大转盘uni-push使用websocket协议实现uniapp+uniCloud实时推送在线互动抽奖项目打包H5微信小程序_咸虾米

嗨,大家好,我是爱搞知识的咸虾米,今天给大家带来的这们课程是使用uni-push实时推送,完成的在线互动抽奖综合项目。 常规的页面只有在手动刷新的时候,才能获取到服务端最新的数据,而websocket可以实现长连…