电脑上不安装Oracle,但是虚拟机装了Oracle,怎么连接到虚拟机里的Oracle数据库呢?

1、准备工作

1.1、确定数据库版本信息

注:如果知道数据库的版本信息,这个步骤可以跳过。

  • 比较简单的方法,直接看数据库的安装位置,也就是数字(但是这个方法确定就是,不好确定是多少位的数据库)
    在这里插入图片描述
  • 另外一种是登录Oracle,查看版本信息(sqlplus 用户名/用户密码)
    在这里插入图片描述

1.2、确定数据库的字符集信息

后面的配置需要
select userenv(‘language’) nls_lang from dual;
查询的字符集为SIMPLIFIED CHINESE_CHINA.ZHS16GBK

在这里插入图片描述

1.3、准备Oracle数据库的客户端软件

注:选一个就可以,这里以PL/SQL Developer为演示
特别注意一点:客户端软件的版本一定对应OracleInstant Client的版本
比如OracleInstant Client的版本为64的,那么客户端软件的版本也应为64的

  • PL/SQL Developer
  • sqldeveloper
  • Toad for Oracle
  • Navicat Premium

1.4、准备Oracle数据库的驱动文件

oracle数据库驱动文件下载地址
Oracle Instant Client Downloads:https://www.oracle.com/cn/database/technologies/instant-client/downloads.html

  • 访问下载地址,可以看到的内容
    在这里插入图片描述

  • 选择对应的操作平台,比如Microsoft Windows x64 平台
    在这里插入图片描述

  • 由于虚拟机数据库版本为11.2.0(且平台为Windows 64的),这里下载Basic版本
    在这里插入图片描述

1.5、准备连接的配置文件

  • 从虚拟机里拷出SAMPLE文件夹里的文件
    在这里插入图片描述
  • 可以看到SAMPLE文件夹下有三个文件(LISTENER.ORA,sqlnet.ora,tnsnames.oRA)
    在这里插入图片描述

1.6、文件准备工作就绪

  • 以下是所有的文件汇总,我这里提前把压缩包给解压出来了,方便后面操作
    在这里插入图片描述

2、查看参数并配置连接文件

2.1、查看网络协议

本工具是Oracle安装时提供的,工具名称为Oracle Net Manager

在这里插入图片描述

  • IPC服务协议配置截图(SIDCLRExtProc密钥名称EXTPROC1521
    在这里插入图片描述

  • TCP/IP服务协议配置截图(服务名、端口号
    在这里插入图片描述

2.2、做连通性测试

此步骤是测试下能否访问到虚拟机地址,语法:ping 虚拟机的ip地址,看发送的数据是否都能收到

在这里插入图片描述

2.3、tnsnames.ora配置

在这里插入图片描述

2.4、新建启动脚本

移动SMPLE到Oracle Instant Client下,然后创建一个启动脚本

  • 先把修改后的SMPLE文件夹移动到Oracle Instant Client下,并创建设置启动环境.bat脚本文件
    在这里插入图片描述

关于字符集怎么查询,请根据1.2的配置查看字符集怎么查看

  • 以下启动脚本的内容,供参考
    @echo off
    title 不要关掉!!!
    mode con cols=38 lines=20
    color 03set file_name_str = %~sdp0
    set ORACLE_HOME = %file_name_str%
    set TNS_ADMIN = %file_name_str%\SMPLE
    set NLS_LANG = SIMPLIFIED CHINESE_CHINA.ZHS16GBK
    rem set NLS_CHARACTERSET=AL32UTF8
    rem set NLS_LANG = AMERICAN_AMERICA.AL32UTF8
    rem set NLS_LANG = SIMPLIFIED CHINESE_CHINA.ZHS16GBKrem 在原有path后追加
    set path=%path%;%file_name_str%
    echo 设置启动环境变量,不要关闭pause
    
  • 接着运行这个脚本文件起来,运行后不要关掉窗口
    在这里插入图片描述

3、配置Oracle驱动的路径

3.1、PL/SQL Developer

  • 设置Oracle目录位置
    在这里插入图片描述

  • 重新打开PL/SQL Developer软件,尝试登录
    在这里插入图片描述
    在这里插入图片描述

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

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

相关文章

二叉树算法思想和原理:介绍通过递归算法计算二叉树结点个数的基本思路及C#、C++代码示例

二叉树是一种非常常见的数据结构,它由结点组成,每个结点最多有两个子结点,分别称为左子结点和右子结点。在二叉树中,每个结点都有一个数据域和一个指针域,指针域分别指向左子结点和右子结点。二叉树有很多种不同的类型…

【Flask】使用 werkzeug 安全地处理密码

使用 werkzeug 安全地处理密码 假设我们要实现一个登录注册的功能,最简单的方式是先创建一个表,有 username 和 password 字段,然后再编写相应的登录和注册接口。 创建表 以下是一个简单的例子,展示了如何创建一个用户表并定义…

day07

1.return关键字的用法return 在有返回值的方法中使用return 返回值;return 关键字书写以后后面的代码就不能写了2.声明方法的四种形式无参无返回值的语法格式有参无返回值的无参有返回值的有参有返回值的3.什么是形参,什么是实参在方法的声明处,写的变量…

年日历实现, 2、维护工作日和休息日, 3、初始化法定节假日

you:请帮我用vue2实现如下功能:1、年日历实现, 2、维护工作日和休息日, 3、初始化法定节假日 当你想要使用Vue.js 2实现年度日历,并维护工作日和休息日以及初始化法定节假日时,你可以考虑以下步骤。 首先&#xff0c…

全志图形引擎 以 F1C200s 为例介绍

全志图形引擎的思路在很多自家芯片上是大差不差的。这些芯片包括但不限于:F1C100s、F1C200s、V3S、A64、T113、H8、H3、A83。 F1C200s 和 F1C100s 相差极小,仅集成内存大小有所差别。 下面以 F1C200s 为例讲解全志图形引擎。 F1C200s的显示系统由以下四部分组成: 时序控制…

使用pandas按照商品和下单人统计下单数据

目录 一:需求描述 二:代码实现 三:注意事项 一:需求描述 最近运营那边给到一个excel表格,是一个小程序用户的下单数据,要以商品为维度,统计用户下单情况,主要是下单的商品总金额&…

多进程 案例

from multiprocessing import Process, Queueclass MyProcess(Process):def __init__(self, q, i):super().__init__()self.q qself.i idef run(self):print(子进程%s 开始put数据 % self.i)self.q.put(我是%s 通过Queue通信 % self.i)self.q.put(我是%s 通过Queue通信 % 2)i…

SpringBoot-Dubbo-Zookeeper

Apache Dubbo&#xff1a;https://cn.dubbo.apache.org/zh-cn/overview/home/ 依赖 <!--dubbo--> <dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId><version>2.7.3</versio…

CMake+大漠插件的应用开发——处理dm.dll,免注册调用大漠插件

文章目录 CMake大漠插件的应用开发——处理dm.dll&#xff0c;免注册调用大漠插件简介环境项目结构配置编译环境编码-直接调用 dll编码-生成tlh文件&#xff0c;便于提示 CMake大漠插件的应用开发——处理dm.dll&#xff0c;免注册调用大漠插件 简介 网上有一种使用方式是&am…

Navicat连接不上虚拟机中linux的dockers创建的mysql

说明&#xff1a;这个问题可能只是我的个人问题&#xff0c;记录一下吧。当发现这个问题的时候&#xff0c;去网上搜素了一下&#xff0c;搜到的文章基本上都是通过在mysql中设置允许远程访问解决的&#xff0c;然后我也跟着尝试了一下&#xff0c;问题并没有解决。后面就乱七八…

golang学习-golang结构体和Json相互转换

1、结构体转为json对象 v, _ : json.Marshal(student) jsonStr : string(v) // 结构体转为json对象 2、json字符串转为结构体 var s1 Student err : json.Unmarshal([]byte(str), &s1) //json 字符串转为结构体 3、结构体标签 表示的是转换为json对象时&#xff0c;ID字段…

allegro PCB设计心得笔记(二) PCB板框设计心得

Cadence Allegro软件设计PCB板框时&#xff0c;使用Add -> line&#xff0c;在Option选择Board Geometry/Outline&#xff0c;根据PCB需要输入对应坐标&#xff0c;设计好板框。 使用Z-Copy命令设计Route Keepin和Package Keepin时&#xff0c;需要先使用使用Shape -> Co…

【Python】Python语言 3小时速通(有C语言基础版)

python从入门到实践 变量 message"hello world"并不需要指出变量类型 方法 tittle()#以首字母大写的形式输出单词upper()#全部大写输出lower()#全部小写输出存储数据时经常使用lower&#xff0c;因为无法确保数据是大写还是小写 rstrip()#输出删除字符串尾部多余…

YOLOv5涨点改进:多层次特征融合(SDI),小目标涨点明显,| UNet v2,比UNet显存占用更少、参数更少

💡💡💡本文全网独家改进:多层次特征融合(SDI),能够显著提升不同尺度和小目标的识别率 💡💡💡在YOLOv5中如何使用 1)iAFF加入Neck替代Concat; 💡💡💡Yolov5/Yolov7魔术师,独家首发创新(原创),适用于Yolov5、Yolov7、Yolov8等各个Yolo系列,专栏文…

RabbitMQ 的基本概念

一 MQ 的基本概念 1 MQ概述 MQ全称 Message Queue&#xff08;消息队列&#xff09;&#xff0c;是在消息的传输过程中保存消息的容器。多用于分布式系统之间进行通信。消息队列就是所谓的存放消息的队列。 消息队列解决的不是存放消息的队列的⽬的&#xff0c;解决的是通信问…

三、GCC编译:链接

代码准备 main.c extern int shared; extern void func(int *a, int *b); int main(){int a 100;func(&a, &shared);return 0; }func.c int shared 1; int tmp 0; void func(int *a, int *b){tmp *a;*a *b;*b tmp; }静态链接 编译 gcc -static -fno-stack-p…

VB6 VBA asp的RecordSet.GetRows方法

1.VBA调用ADO执行SQL语句获取查询结果&#xff0c;通过RecordSet.GetRows方法获取到的数组是行列转置后的数组。 2.如果通过application.transpose对RecordSet.GetRows方法获取到的数组再进行转置&#xff0c;如果报错“运行时错误438&#xff1a;对象不支持该属性或方法”&am…

TypeScript学习笔记、鸿蒙开发学习笔记

变量定义方式 # 变量声明 let msg: string douzi console.log(msg) let num: number 20 console.log(num) let end: boolean true console.log("end" end) let a: any 10 a douzi console.log(a) let p {name:"douzi",age:20} console.log(p.name)…

hls转流服务的nginx配置和一些脚本

前言 当今&#xff0c;流媒体服务已成为互联网中不可或缺的重要组成部分。HLS&#xff08;HTTP Live Streaming&#xff09;作为一种流媒体传输协议&#xff0c;被广泛应用于视频直播、点播等应用场景中。而Nginx作为一款高性能的Web服务器&#xff0c;也可以被用于构建HLS转流…

《每天十分钟》-红宝书第4版-集合引用类型(二)

接着奏乐接着抄&#xff0c;续着上篇的数组 迭代器方法 const a ["zhangsan", "lisi", "wangwu"]; // 因为这些方法都返回迭代器&#xff0c;所以可以将它们的内容 // 通过 Array.from()直接转换为数组实例 const aKeys Array.from(a.keys(…