在Mac OS X上安装Oracle客户端
在mac上安装oracle客户端
官网下载页面
http://www.oracle.com/technetwork/topics/intel-macsoft-096467.html
选择适合的版本下载
instantclient-basic-macos.x64-12.2.0.1.0-2.zip
instantclient-basiclite-macos.x64-12.2.0.1.0-2.zip
instantclient-jdbc-macos.x64-12.2.0.1.0-2.zip
instantclient-odbc-macos.x64-12.2.0.1.0-2.zip
instantclient-sdk-macos.x64-12.2.0.1.0-2.zip
instantclient-sqlplus-macos.x64-12.2.0.1.0-2.zip
instantclient-tools-macos.x64-12.2.0.1.0-2.zip
Instant Client Package - Basic: All files required to run OCI, OCCI, and JDBC-OCI applications
instantclient-basic-macos.x64-12.2.0.1.0-2.zip (68,160,048 bytes) (cksum - 2145539248)

登录/注册Oracle账号
会跳到登录界面,要是没有账号就需要注册一个,然后才能下载。
下载完成之后,解压客户端压缩文件
将里边的全部文件放到~/lib 或者 /usr/local/lib 或者/opt/oracle/instanceclient 文件下
下载完后会有一个instantclient 的压缩包,后边会有版本号,如我下载的是instantclient_12_2,
解压,会有以下文件 ,将里边的文件,全部复制到~/lib 或者 /usr/local/lib 或者/opt/oracle/instanceclient文件下
- 放在任何位置都可以,关键是环境变量设置时,需要export相应的PATH即可
设置环境变量
下面是我自己的目录存放位置,将/opt/oracle/instanceclient要改成你自己的目录。
在你的设置环境变量的文件夹中添加:
vim ~/.bash_profile
export PATH=$PATH:/opt/oracle/instanceclient
source ~/.bash_profile
## language setup export NLS_LANG=AMERICAN_AMERICA.UTF8
export OCI_HOME=/opt/oracle/instantclient
export OCI_LIB_DIR=$OCI_HOME
export OCI_INCLUDE_DIR=$OCI_HOME/sdk/include
export OCI_VERSION=11
export DYLD_LIBRARY_PATH=$OCI_LIB_DIR
PATH=$PATH:$OCI_HOME
export PATH

Node安装oracledb
1.安装oracledb依赖
npm install oracledb
2.编写连接代码
var oracledb = require('oracledb');
var config = {
user:'******', //用户名
password:'******', //密码
//IP:数据库IP地址,PORT:数据库端口,SCHEMA:数据库名称
connectString : "IP:PORT/SCHEMA"
};
oracledb.getConnection(
config,
function(err, connection){
if (err) {
console.error(err.message);
return;
}
//查询某表十条数据测试,注意替换你的表名
connection.execute("SELECT * FROM ( SELECT A.*, ROWNUM RN FROM (SELECT * FROM 你的表名) A WHERE ROWNUM <= 10 ) WHERE RN >= 0",
function(err, result){
if (err) {
console.error(err.message);
doRelease(connection);
return;
}
//打印返回的表结构
console.log(result.metaData);
//打印返回的行数据
console.log(result.rows);
});
});
function doRelease(connection){
connection.close(
function(err) {
if (err) {
console.error(err.message);
}
});
}
3. 执行代码
node app.js
4. 输出结果

参考资料:https://github.com/oracle/node-oracledb/blob/master/INSTALL.md#instzip
1万+

被折叠的 条评论
为什么被折叠?



