一、通过JDBC连接Oracle数据库

小编通过JDBC连接Oracle数据库,步骤如下啊;

1、找到jdbc的驱动程序文件并复制

位置在Oracle安装基目录product11.2.0dbhome_1jdbclibojdbc6.jar,然后将它复制到matlab安装目录的java子目录…MATLABR2016ajavajartoolbox下;

2、修改matlab的classpath文件

该文件在...MATLABR2013atoolboxlocalclasspath.txt,于结尾添加一行:$matlabroot/java/jar/toolbox/ojdbc6.jar

3、建立连接的命令并测试

如果需要新建立连接(PS:小编这里创建的表空间、用户名和密码都是MATLAB123),可以创建MATLAB123表空间及用户:点击左侧连接选项卡列表中sys连接左侧的加号,连接sys用户并输入如下sql语句,点击工具栏运行脚本按钮



create tablespace MATLAB123 datafile 'D:/ MATLAB123.dbf' size 500m;
create user MATLAB123 identified by MATLAB123 default tablespace MATLAB123;
grant connect, resource to MATLAB123;





matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_.net插入到oracle中


PS:如果各位忘了sys的密码,可以按照下面步骤进行修改(原文链接:https://zhidao.baidu.com/question/591397847.html):

1、win键+R键,输入cmd,打开命令提示符
2、输入:sqlplus /nolog


matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_数据库_02


3、输入conn /as sysdba


matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_.net插入到oracle中_03


4、输入alter user sytem identified by 新密码


matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_数据库_04


在新创建完用户以后(或者使用原来已经有的用户),需要在MatLab命令行窗口输入以下数据库连接字符串:


conn_jdbc=database('sid_name','username','password','driverName','连接字符串')


sid_name:这里不是services_name

username:用户名

password:密码

driverName:驱动名称—’oracle.jdbc.driver.OracleDriver’

连接字符串:‘jdbc:oracle:thin:@localhost:1521:sid_name’

注意:jdbc连接数据库的时候,需要使用数据库的sid_name,而不是数据库的services_name。

查询sid_name有两种方法:

方法一:通过以下sql语句查询(可能是因为我新建的用户,所以使用这个命令不好用,但我使用了第二种办法):


select instance_name from v$instance;


方法二:在sqldeveloper里直接查看


matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_MATLAB_05


4. 通过ping命令查看连接状况


ping(conn_jdbc)


5. 常见连接错误

ORA-12505, TNS:listener does not currentlyknow of SID given in connect descriptor修改方案就是检查sid_name是否写错了。

原文链接:

二、在matlab中调用Oracle数据

在成功连接Oracle数据库以后,接下来要在matlab里实现对Oracle数据库的查询及插入操作。

1、插入操作

但如果是新建的数据库的话,需要新建立一个数据表,小编在这里建立一个名为“CITY”的数据表,这个表共有三列“CITY_NO”、“CITY_X”、“CITY_Y”,需要强调的是,使用MATLAB插入数据前必须先建好表,然后才能插入数据


matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_MATLAB_06


建完表后,在matlab输入如下语句:


fastinsert(conn, 'tablename', colnames, exdata)


参数说明: tablename:表名 colnames:列名 exdata:待插入的数据示例:


%执行插入
fastinsert(conn_jdbc,'CITY',{'CITY_NO','CITY_X','CITY_Y'},{2,1,1});   %注意因为建立表的时候选择数据属性为NUMBER,所以这里需要添加的是数字


执行之后,在sql developer中查看,发现数据添加成功


matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_.net插入到oracle中_07


2、查询操作
在matlab输入以下语句查询“CITY”数据表中的数据


curs=exec(conn_jdbc,'select CITY_NO,CITY_X,CITY_Y from CITY ');
curs=fetch(curs);
data=curs.Data;


data是一个cell数组,打开data数组,即可查看从“CITY”数据表中的数据。


matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_数据库_08


原文链接:

三、MATLAB代码


clear
clc
%% 连接Oracle数据库
conn_jdbc=database('sid_name','MATLAB123','MATLAB123','oracle.jdbc.driver.OracleDriver','jdbc:oracle:thin:@localhost:1521:sid_name');    %把sid_name替换成自己的,MATLAB123也是我自己的用户名和密码,也需要替换成自己的
ping(conn_jdbc)
%% 实现插入功能
fastinsert(conn_jdbc,'CITY',{'CITY_NO','CITY_X','CITY_Y'},{2,1,1});
%% 实现查询功能
curs=exec(conn_jdbc,'select CITY_NO,CITY_X,CITY_Y from CITY ');
curs=fetch(curs);
data=curs.Data;


更多资源请微信关注优化算法交流地

往期精彩

机器学习 | 基于遗传算法的BP神经网络优化算法(附MATLAB代码)mp.weixin.qq.com

matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_bc_09

机器学习 | 简单实现Bp神经网络mp.weixin.qq.com

matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_数据库_10

二维装箱问题之BL法修正版(附MATLAB代码)mp.weixin.qq.com

matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_.net插入到oracle中_11

快速入门文献管理软件-EndNote X9mp.weixin.qq.com

matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_.net插入到oracle中_12

最小二乘法(附MATLAB代码)mp.weixin.qq.com

matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_MATLAB_13

VRPTW合集 [CW节约算法,TS(硬约束版),TS(惩罚函数版),LNS四种方法对比(附MATLAB代码)]mp.weixin.qq.com

matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_数据库_14

NSGA-II多目标优化算法讲解(附MATLAB代码)mp.weixin.qq.com

matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_bc_15

基于人工势场法的机器人二维路径规划(附MATLAB代码)mp.weixin.qq.com

matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_bc_16

基于粒子群算法的多目标搜索算法讲解(附MATLAB代码)mp.weixin.qq.com

matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_.net插入到oracle中_17

蚁群算法通俗讲解(附MATLAB代码)mp.weixin.qq.com

matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_.net插入到oracle中_18

混合粒子群算法通俗讲解(附MATLAB代码)mp.weixin.qq.com

matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_.net插入到oracle中_19

遗传算法求解车间调度问题(附MATLAB代码)mp.weixin.qq.com

matlab 连接mysql数据库和关闭数据库 matlab连接oracle数据库_数据库_20