erlang-db-driver是北京融易通公司开源的一个erlang支持众多数据库的一个驱动类库,据其wiki介绍,其支持MySQL, Oracle, Sybase, DB2 and Informix,功能不可不说强劲。

公司的业务支持oracle,使用的是odbc方法,为了提高性能,特转换为使用erlang-db-driver。在使用的过程中,遇到了很多问题,不过通过邮件跟融易通公司的工程师联系,得到了他们的快速回复,解决了不少问题。本文是集合了我们联系的邮件而形成的一个概括文档。如果你们在使用erlang-db-driver有问题,不妨给他们发邮件,他们是很乐意解决你们的问题的。

1.安装Oracle Database Instant Client

oracle客户端类库中下载安装需要的类库,其中必须的是Basic、devel2个文件。也可以安装SQL PLUS文件,可以通过命令行来连接oracle服务器。

2.链接动态类库

安装的类库在/usr/lib,要使我们的程序连接到oracle类库,我们要执行下面命令:

cd /usr/lib/oracle/12.1/client/lib
pwd >> /etc/ld.so.conf
ldconfig

设置环境变量

export ORACLE_HOME=/usr/lib/oracle/12.1/client

第2步到现在,基于一个假设,即oracle的客户端和服务器端是在不同的主机上的。

如果oracle的客户端和服务器端是在相同的主机上的,可以设置erlang-db-driver里面的build/oracle.config文件。

{check_envs, [
    "ORACLE_HOME"
]}.
 
{include_search_dirs, [
    "${ORACLE_HOME}",
    "/usr/include/oracle/",
    "/usr/local/include/oracle",
    "/usr/local/oracle/include",
    "/opt/local/include/oracle"
]}.
 
{include_files, [
    "occi.h"
]}.
 
{lib_search_dirs, [
    "${ORACLE_HOME}/lib",
    "${ORACLE_HOME}"
]}.
 
{lib_files, [
    "occi",
    "clntsh"
]}.
 
{cflags, "-DUSE_ORACLE"}.
 
{srcs, ["c_src/oracle/*.cpp"]}.
 
你可以将里面的ORACLE_HOME改成客户端的路径,然后重新编译。
 
3.下载编译erlang-db-driver项目
准备阶段,安装erlang-db-driver编译需要的文件:
yum install git doxygen graphviz

下载erlang-db-driver

git clone https://github.com/denglf/erlang-db-driver

编译安装:

cd erlang-db-driver
./configure --with-oracle
make
make docs
make installl

至此,erlang-db-driver安装完毕。

4.配置tnsnames.ora文件

配置tnsnames.ora跟odbc连接oracle的方式很像。

oracle的连接配置在配置文件中
$ORACLE_HOME/network/admin/tnsnames.ora
内容如下:
MY_DB_CONNECTION =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.95)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = XE)
)
)

EXTPROC_CONNECTION_DATA =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC))
)
(CONNECT_DATA =
(SID = PLSExtProc)
(PRESENTATION = RO)
)
)

对应命令行,你可以通过下面的命令连接oracle数据库:
sqlplus SYSTEM/@192.168.0.95:/XE

连接参数如下:
[
{default_pool, true},
{table_info, true},
{driver, oracle},
{host, ""},
{port, 1521},
{user, "SYSTEM"},
{password, "123456"},
{database, "MY_DB_CONNECTION"}, %% 这里是配置文件里所配的名称
{poolsize, 8}]

erl
>db_app:start().
>ConnArg = [
{default_pool, true},
{table_info, true},
{driver, oracle},
{host, ""},
{port, },
{user, "SYSTEM"},
{password, ""},
{database, "MY_DB_CONNECTION"},
{poolsize, }].
> db_app:add_pool(xell, ConnArg).

这样就可以连接oracle数据库了。

5.在64位系统下找不到erlang_interface

上面使用的系统的是32位的centos,如果是64位的系统,要使用下面的命令来规避这个问题。

cd /usr/local/lib64 && ln -s /usr/local/lib/erlang .

可以看这里了解这个问题。

6.插入日期数据。

假设有个简单表,ss表定义只有date数据类型

CREATE TABLE    ss (
toptime date NOT NULL
);

可以使用下面的语句插入数据:

db_app:execute_sql("insert into ss(toptime) values( to_date('2013-12-5 10:3:9', 'YYYY-MM-DD HH24:MI:SS'))").

也可以这样:

db_app:insert(ss, [{toptime,{"datetime", {{2013, 12, 5}, {2,3,4}}}}]).

安装配置erlang_db_driver的更多相关文章

  1. Hive安装配置指北(含Hive Metastore详解)

    个人主页: http://www.linbingdong.com 本文介绍Hive安装配置的整个过程,包括MySQL.Hive及Metastore的安装配置,并分析了Metastore三种配置方式的区 ...

  2. Hive on Spark安装配置详解(都是坑啊)

    个人主页:http://www.linbingdong.com 简书地址:http://www.jianshu.com/p/a7f75b868568 简介 本文主要记录如何安装配置Hive on Sp ...

  3. ADFS3.0与SharePoint2013安装配置(原创)

    现在越来越多的企业使用ADFS作为单点登录,我希望今天的内容能帮助大家了解如何配置ADFS和SharePoint 2013.安装配置SharePoint2013这块就不做具体描述了,今天主要讲一下怎么 ...

  4. Hadoop的学习--安装配置与使用

    安装配置 系统:Ubuntu14.04 java:1.7.0_75 相关资料 官网 下载地址 官网文档 安装 我们需要关闭掉防火墙,命令如下: sudo ufw disable 下载2.6.5的版本, ...

  5. redis的安装配置

    主要讲下redis的安装配置,以及以服务的方式启动redis 1.下载最新版本的redis-3.0.7  到http://redis.io/download中下载最新版的redis-3.0.7 下载后 ...

  6. Windows环境下的NodeJS+NPM+Bower安装配置

    npm作为一个NodeJS的模块管理,之前我由于没有系统地看资料所以导致安装配置模块的时候走了一大段弯路,所以现在很有必要列出来记录下.我们要先配置npm的全局模块的存放路径以及cache的路径,例如 ...

  7. ubuntu kylin 14.04安装配置MongoDB v2.6.1(转)

    1.获取最新版本 https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-2.6.1.tgz 2.解压并进入bin目录 tar zxvf mongo ...

  8. Django基础之安装配置

    安装配置 一 MVC和MTV模式 著名的MVC模式:所谓MVC就是把web应用分为模型(M),控制器(C),视图(V)三层:他们之间以一种插件似的,松耦合的方式连接在一起. 模型负责业务对象与数据库的 ...

  9. 【转】Windows平台下的Subversion安装配置新手指南

    原文地址:http://developer.51cto.com/art/201005/199628.htm 本文介绍Subversion安装配置快速指南,首先讲Subversion的安装和配置,Uni ...

随机推荐

  1. restframework中的那些参数你知道吗?

    序列化是很重要的过程, 在构建数据结构的时候, 往往会出现很多意想不到的问题, 有一些参数你要用, 但是没有办法穿过来, 怎么办> 今天这篇博客就是写我之前的一个小项目中用restframewo ...

  2. Git简单配置ssh秘钥

    执行以下命令: git config --global user.name "demo" git config --global user.email "demo@dem ...

  3. laravel4.2 Redis 使用

    laravel4.2 Redis 使用 配置文件,app/config/database.php 'redis' => array( 'cluster' => false, 'defaul ...

  4. python学习笔记:第15天 初识面向对象

    目录 1. 面向对象和面向过程 2. 面向对象如何编写: 3. 面向对象的三大特征 封装 继承 多态 1. 面向对象和面向过程 面向对象和面向过程的理解: ⾯向过程: ⼀切以事物的流程为核⼼. 核⼼是 ...

  5. 决策树&随机森林

    参考链接: https://www.bilibili.com/video/av26086646/?p=8 <统计学习方法> 一.决策树算法: 1.训练阶段(决策树学习),也就是说:怎么样构 ...

  6. python神坑系列之深浅拷贝

    深浅拷贝 1.注意在拷贝中只有使用了.deepcopy方法才能进行深度拷贝!其余的一律是浅拷贝 #深拷贝import copy lst = copy.deepcopy(lst1)  浅拷贝: 拷贝的是 ...

  7. 从零开始一个http服务器(四)-动态返回

    从零开始一个http服务器(四) 代码地址 : https://github.com/flamedancer/cserver git checkout step4 运行: make clean &am ...

  8. BAT-运行程序

    @echo offrem copy C:\Users\Administrator\Desktop\0000\123.txt C:\Users\Administrator\Desktop\0000\45 ...

  9. 关于Json.dumos中的ensure_ascii

    在使用json,dumps时,当需要输出中文时,需要在后面添加  ensure_ascii = Fasle 因为json.dumps 序列化时,默认对中文使用的是 ascii 编码,添加后才能输出中文 ...

  10. Vue.js核心概念

    # 1. Vue.js是什么? 1). 一位华裔前Google工程师(尤雨溪)开发的前端js库 2). 作用: 动态构建用户界面 3). 特点: * 遵循MVVM模式 * 编码简洁, 体积小, 运行效 ...