一、通过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;
PS:如果各位忘了sys的密码,可以按照下面步骤进行修改(原文链接:https://zhidao.baidu.com/question/591397847.html):
1、win键+R键,输入cmd,打开命令提示符
2、输入:sqlplus /nolog
3、输入conn /as sysdba
4、输入alter user sytem identified by 新密码
在新创建完用户以后(或者使用原来已经有的用户),需要在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里直接查看
4. 通过ping命令查看连接状况
ping(conn_jdbc)
5. 常见连接错误
ORA-12505, TNS:listener does not currentlyknow of SID given in connect descriptor修改方案就是检查sid_name是否写错了。
原文链接:https://blog.csdn.net/a36567/article/details/80012995
二、在matlab中调用Oracle数据
在成功连接Oracle数据库以后,接下来要在matlab里实现对Oracle数据库的查询及插入操作。
1、插入操作
但如果是新建的数据库的话,需要新建立一个数据表,小编在这里建立一个名为“CITY”的数据表,这个表共有三列“CITY_NO”、“CITY_X”、“CITY_Y”,需要强调的是,使用MATLAB插入数据前必须先建好表,然后才能插入数据
建完表后,在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中查看,发现数据添加成功
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”数据表中的数据。
原文链接:https://www.cnblogs.com/imyao/p/5578476.html
三、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;
更多资源请微信关注:优化算法交流地