Oracle Database 21c Express Edition数据库 和 Sqlplus客户端安装配置

目录

  • 一. 前置条件
  • 二. Win10安装配置Oracle数据库
    • 2.1 数据库获取
    • 2.2 数据库安装
    • 2.3 数据库配置确认
    • 2.4 数据库访问
  • 三. Win10配置Oracle数据库可对外访问
    • 3.1 打开文件和打印机共享
    • 3.2 开放1521端口
  • 四. 端口与地址确认
    • 4.1 查看监听器的状态
    • 4.2 Win10查看1521端口是否被监听
    • 4.3 Ubuntu虚拟机测试与Win10虚拟机的连接
  • 五. Ubuntu虚拟机安装配置Sqlplus客户端
    • 5.1 获取Sqlplus客户端
    • 5.2 安装配置Sqlplus客户端
    • 5.3 libaio库配置
    • 5.4 解决乱码问题


一. 前置条件

  • 虚拟机中有两个操作系统
    • Win10
    • Ubuntu-24.04.1
  • 在Win10的虚拟机中安装Oracle数据库
  • 本机通过ssh连接Ubuntu虚拟机,然后在虚拟机中连接Win10中的oracle

二. Win10安装配置Oracle数据库

2.1 数据库获取

  • Oracle Database Express Edition (XE) Downloads 官网
    • https://www.oracle.com/cn/database/technologies/xe-downloads.html
  • Oracle Database 21c Express Edition for Windows x64 下载链接
    • https://download.oracle.com/otn-pub/otn_software/db-express/OracleXE213_Win64.zip

2.2 数据库安装

⏹ 解压安装包之后,通过setup.exe一步步安装即可。
在这里插入图片描述
⏹ 安装的详细过程可参考这篇博客
https://www.cnblogs.com/Javaer1995/p/17485495.html

⏹默认情况下会安装在如下路径中

C:\app\用户名\product\21c\

2.3 数据库配置确认

⏹环境变量确认
在这里插入图片描述

⏹listener.ora和tnsnames.ora的确认

  • 路径
    • C:\app\用户名\product\21c\homes\OraDB21Home1\network\admin
  • 作用
    • 重要的网络配置文件,用于支持客户端与数据库之间的连接。
    • listener.ora 文件定义了数据库监听器的配置信息。监听器是一个服务器端进程,负责监听客户端的连接请求,并将请求转发给相应的数据库实例。
    • tnsnames.ora 文件在客户端侧用于定义数据库连接字符串的别名。它让用户通过简单的名称连接数据库,而不需要记住复杂的网络配置信息。
  • 💥注意点💥
    tnsnames.oralistener.ora中的配置和电脑名称又关联性,当电脑名称修改之后,不修改对应的配置文件,会无法访问oracle
    在这里插入图片描述

2.4 数据库访问

  • 账户名:system(oracle自带的系统账户)
  • 密码: oracle
sqlplus system/oracle@192.168.118.137

⏹可以看到成功登录oracle数据库

在这里插入图片描述


三. Win10配置Oracle数据库可对外访问

3.1 打开文件和打印机共享

⏹如下图所示,打开文件和打印机共享

  • 如果不打开的话,外部计算机无法通过ping命令访问到虚拟机

在这里插入图片描述

3.2 开放1521端口

⏹Oracle默认监听1521端口,开放1521端口,确保外部可以通过1521端口访问到Oracle数据库

  • 如下图所示,通过防火墙的高级设置,进入入站规则

在这里插入图片描述

⏹添加入站规则:

  • 在左侧点击 入站规则。
  • 在右侧点击 新建规则。
  • 在规则类型中选择 端口,然后点击 下一步。
  • 选择 TCP,并在“特定本地端口”中输入 1521。
  • 点击 下一步,选择 允许连接。
  • 点击 下一步,根据需求勾选 域、专用、公用。
  • 点击 下一步,为规则命名(例如“Oracle 1521 TCP”),然后完成。

在这里插入图片描述


四. 端口与地址确认

4.1 查看监听器的状态

# 查看监听器的状态
lsnrctl status
# 监听器没有启动的话,启动监听器
lsnrctl start

在这里插入图片描述

4.2 Win10查看1521端口是否被监听

netstat -an | findstr 1521

在这里插入图片描述

4.3 Ubuntu虚拟机测试与Win10虚拟机的连接

  • 查看与目标服务器IP地址是否能ping通
  • 查看是否能访问目标服务器的指定端口
ping 目标服务器ip地址
telnet 目标服务器ip地址 1521

在这里插入图片描述


五. Ubuntu虚拟机安装配置Sqlplus客户端

5.1 获取Sqlplus客户端

  • 官方网站
    https://www.oracle.com/cn/database/technologies/instant-client/linux-x86-64-downloads.html
  • Sqlplus客户端安装包
    • ⏹instantclient-basic-linux.x64-21.16.0.0.0dbru.zip
      • https://download.oracle.com/otn_software/linux/instantclient/2116000/instantclient-basic-linux.x64-21.16.0.0.0dbru.zip
    • ⏹instantclient-sqlplus-linux.x64-21.16.0.0.0dbru.zip
      • https://download.oracle.com/otn_software/linux/instantclient/2116000/instantclient-sqlplus-linux.x64-21.16.0.0.0dbru.zip

在这里插入图片描述

5.2 安装配置Sqlplus客户端

⏹创建客户端所在的文件夹,将zip文件解压到指定的文件夹中

# 创建客户端所在的文件夹
mkdir -p /opt/oracle/instantclient

# 将zip文件解压到指定的文件夹中
unzip instantclient-basic-linux*.zip -d /opt/oracle/instantclient
unzip instantclient-sqlplus-linux*.zip -d /opt/oracle/instantclient

⏹配置环境变量

  • 编辑.bashrc文件
vim ~/.bashrc
  • .bashrc末尾追加下面的内容
# oracle客户端的路径
export ORACLE_BASE=/opt/oracle/instantclient
# oracle客户端实例的路径
export ORACLE_HOME=$ORACLE_BASE/instantclient_21_16
# 动态库的路径
export LD_LIBRARY_PATH=$ORACLE_HOME:$LD_LIBRARY_PATH

# 将$ORACLE_HOME加入PATH中,下面这种写法可以避免既存的PATH环境变量被覆盖
export PATH=$ORACLE_HOME:$PATH
  • 使配置生效
source ~/.bashrc

⏹配置远程连接,定义远程数据库服务

  • 创建tnsnames.ora文件
touch $ORACLE_HOME/network/admin/tnsnames.ora
  • 编辑如下内容到tnsnames.ora文件中
    • HOST:远程oracle的地址
    • SERVICE_NAME:远程oracle的实例
apluser@ubuntu24-01:~$ cat $ORACLE_HOME/network/admin/tnsnames.ora
ORCL =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.118.137)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = XE)
    )
  )

5.3 libaio库配置

⏹按照上述配置完成之后,在控制台输入sqlplus,会出现如下错误,提示sqlplus运行缺少libaio.so.1

apluser@ubuntu24-01:~$ sqlplus
sqlplus: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory

⏹在网上搜索了很多资料,基本上都会提示让安装如下库

sudo apt update
sudo apt install libaio1

⏹但在24.04.1 LTS的ubuntu安装时,出现了如下的错误

# 我的ubuntu版本
apluser@ubuntu24-01:~$ cat /etc/os-release | grep VERSION=
VERSION="24.04.1 LTS (Noble Numbat)"
# 实际安装时,出现了下面的错误
apluser@ubuntu24-01:~$ sudo apt install libaio1
[sudo] password for apluser:
Reading package lists... Done
Building dependency tree... Done
Reading state information... Done
Package libaio1 is not available, but is referred to by another package.
This may mean that the package is missing, has been obsoleted, or
is only available from another source

E: Package 'libaio1' has no installation candidate

⏹终于在下面这篇文章中找到了解决办法
https://askubuntu.com/questions/1511776/ubuntu-24-04-php-8-3-oci8-and-libaio-so-1

  • 安装libaio1t64
  • libaio.so.1t64创建链接,指向/libaio.so.1
sudo apt-get install libaio1t64
ln -s /usr/lib/x86_64-linux-gnu/libaio.so.1t64 /usr/lib/x86_64-linux-gnu/libaio.so.1

5.4 解决乱码问题

😵按照如上配置之后,使用sqlplus愉快的连接oracle数据库,却发现存在如下如图所示的乱码问题

在这里插入图片描述

🤔如果 sqlplus 使用的字符集与服务器端的字符集不匹配,可能会导致乱码问题。

  • 通过如下SQL在oracle数据库中进行确认
  • 可以看到oracle数据库的字符集是AL32UTF8
SELECT * FROM NLS_DATABASE_PARAMETERS WHERE PARAMETER LIKE '%CHARACTERSET%';

在这里插入图片描述

👍通过如下设置,确保客户端的环境变量 NLS_LANG 与数据库的 NLS_CHARACTERSET 一致

export NLS_LANG=AMERICAN_AMERICA.AL32UTF8

😜可以看到乱码的问题最终得到了解决

在这里插入图片描述

🧐如果不想每次进入终端时都手动进行设置,可以配置到.bashrc文件中

echo "export NLS_LANG=AMERICAN_AMERICA.AL32UTF8" >> ~/.bashrc
source ~/.bashrc

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

10篇--图像噪点消除

概念 何为噪点? 噪点:指图像收到的一些干扰因素,通常是由图像采集设备、传输信道等因素造成的,表现为图像中随机的亮度,也可以理解为有那么一些点的像素值与周围的像素值格格不入。 常见的噪声类型 高斯噪声&#…

【开源免费】基于Vue和SpringBoot的渔具租赁系统(附论文)

本文项目编号 T 005 ,文末自助获取源码 \color{red}{T005,文末自助获取源码} T005,文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析 六、核心代码6.1 渔…

Linux网络基础-----传输层UDP协议

目录 端口号: 查询各类服务的端口号 加深理解端口号: UDP协议 UDP协议特点: 关于缓冲区: 内核层面理解UDP报文 端口号: 知名端口号:0 ~ 1023:被HTTP、SSH等应用层协议广泛使用的端口号&…

XXE靶场

XXE-lab 靶场 靶场网址&#xff1a;http://172.16.0.87/ 第一步我们看到网站有登录框我们试着用 bp 去抓一下包 将抓到的包发到重放器中 然后我们构建palody <!DOCTYPE foo [ <!ENTITY xxe SYSTEM "php://filter/readconvert.base64-encode/resourceC:/flag/fla…

ubuntu+ros新手笔记(三):21讲没讲到的MoveIt2

1 安装MoveIt2 安装参照在ROS2中&#xff0c;通过MoveIt2控制Gazebo中的自定义机械手 安装 MoveIt2可以选择自己编译源码安装&#xff0c;或者直接从二进制安装。 个人建议直接二进制安装&#xff0c;可以省很多事。 sudo apt install ros-humble-moveitmoveit-setup-assistan…

运维 mysql、redis 、RocketMQ性能排查

MySQL查看数据库连接数 1. SHOW STATUS命令-查询当前的连接数 MySQL 提供了一个 SHOW STATUS 命令&#xff0c;可以用来查看服务器的状态信息&#xff0c;包括当前的连接数。 SHOW STATUS LIKE Threads_connected;这个命令会返回当前连接到服务器的线程数&#xff0c;即当前…

jmeter连接mysql

查询mysql数据库版本 SELECT VERSION(); 下载jmeter mysql 驱动jar包&#xff0c;版本低于mysql版本&#xff0c;放在jmeter的lib 路径下 MySQL :: Download MySQL Connector/J (Archived Versions) 添加JDBC Connection Configuration 填写 variable name 及数据库信息 注意…

Docker的容器

目录 1. 什么是容器&#xff1f;2. 容器的生命周期2.1 容器处理OOM事件2.2 容器异常退出2.3 容器暂停 3. 容器命令详解3.1 容器命令清单3.2 docker create命令3.3 docker run命令3.4 docker ps命令3.5 docker logs命令3.6 docker attach命令3.7 docker exec命令3.8 docker stat…

JAVA题目笔记(二十六)反射

一、保存信息 Student类&#xff1a; package testpackage;import java.io.IOException;public class Student {private String name;private String area;public String testfield;private int age;public Student() {}public Student(String name, String area, int age) {t…

python 配置 oracle instant client

1.问题描述 想用python连接oracle数据库&#xff0c;百度得知需要cx_Oracle这个第三方库 import cx_Oracle# 设置Oracle数据源名称 dsn cx_Oracle.makedsn(host, port, service_nameservice_name)# 创建数据库连接 connection cx_Oracle.connect(userusername, passwordpas…

皮肤伤口分割数据集labelme格式248张5类别

数据集格式&#xff1a;labelme格式(不包含mask文件&#xff0c;仅仅包含jpg图片和对应的json文件) 图片数量(jpg文件个数)&#xff1a;284 标注数量(json文件个数)&#xff1a;284 标注类别数&#xff1a;5 标注类别名称:["bruises","burns","cu…

Ollama配置与webUI本地部署-学习记录

Ollama 前言一、Ollama的下载与安装设置(windows)1.下载2.安装与配置1.查看环境变量&#xff1a;2.设置环境变量&#xff1a;3.设置变量 二、使用步骤1.查找模型2.使用Ollama1.下载模型2.使用 三、WebUI部署WebUI 总结 前言 Ollama是一款可以开始使用本地的大型语言模型。启动…

vscode不同项目使用不同插件

转载请注明出处&#xff1a;小帆的帆的博客 在使用vscode开发不同项目时可能会用到不同的插件。手动管理不够优雅&#xff0c;本文介绍使用Profiles的方式的来管理不同项目的插件。 手动管理不同项目的插件 本来vscode安装了有三个插件 这时需要新建一个项目&#xff0c;新…

数据结构 ——前缀树查词典的实现

数据结构 ——前缀树查词典的实现 一、前缀树的概念 前缀树是一种多叉树结构&#xff0c;主要用于存储字符串。每个节点代表一个字符&#xff0c;路径从根节点到叶节点表示一个完整的字符串。前缀树的关键特征是 共享前缀&#xff0c;也就是说&#xff0c;如果两个字符串有相…

H5 中 van-popup 的使用以及题目的切换

H5 中 van-popup 的使用以及题目的切换 在移动端开发中&#xff0c;弹窗组件是一个常见的需求。vant 是一个轻量、可靠的移动端 Vue 组件库&#xff0c;其中的 van-popup 组件可以方便地实现弹窗效果。本文将介绍如何使用 van-popup 实现题目详情的弹窗展示&#xff0c;并实现…

leetcode 36.有效的数独

1.题目要求: 2.题目步骤: 写好判断函数 3.题目代码: class Solution { public:bool isvalid(vector<vector<char>>& board,char num,int row,int col){//先找左下标int leftrow row - 1;while(leftrow > 0){if(board[leftrow][col] num){return fals…

ElasticSearch中的深度分页问题

在使用 ElasticSearch 进行搜索时&#xff0c;很多小伙伴会遇到“深度分页”问题。当需要获取大量的分页数据时&#xff0c;查询性能会急剧下降&#xff0c;甚至导致集群负载过高。这篇文章将深入剖析 ElasticSearch 深度分页的成因、危害&#xff0c;并提供一些常用的优化方案…

Eureka学习笔记-服务端

Eureka学习笔记 服务端 模块设计 Resources &#xff1a;这部分对外暴露了一系列的 Restful 接口。Eureka Client 的注册、心跳、获取服务列表等操作都需要调用这些接口。另外&#xff0c;其他的 Server 在同步 Registry 时也需要调用这些接口。Controller &#xff1a;这里提…

快速上手:利用 FFmpeg 合并音频文件的实用教程

FFmpeg 是一个强大的多媒体处理工具&#xff0c;能够轻松地对音频、视频进行编辑和转换。本文将介绍如何使用 FFmpeg 来合并&#xff08;拼接&#xff09;多个音频文件为一个单一文件。无论您是想要创建播客、音乐混音还是其他任何形式的音频项目&#xff0c;这都是一个非常实用…

在 CUDA C/C++ 中使用共享內存

文章结尾有最新热度的文章,感兴趣的可以去看看。 本文是经过严格查阅相关权威文献和资料,形成的专业的可靠的内容。全文数据都有据可依,可回溯。特别申明:数据和资料已获得授权。本文内容,不涉及任何偏颇观点,用中立态度客观事实描述事情本身 文章有点长(4700字),期望您…