码迷,mamicode.com
首页 > 数据库 > 详细

erlang连接mysql [转]

时间:2015-04-11 17:43:21      阅读:173      评论:0      收藏:0      [点我收藏+]

标签:

 

转自: http://blog.csdn.net/flyinmind/article/details/7740540

 

项目中用到erlang,同时也用到mysql。惯例,google。

但是,按照网上说的做,有些出入,行不通,需要自己摸索,下面记录我摸索的东西。

1、下载erlang-mysql-driver;

下载地址:https://github.com/dizzyd/erlang-mysql-driver

 

2、解压到mysql目录,不罗嗦了;

 

3、编译

要先配置erlang路径,在/etc/profile中,将erlang的bin路径写入比如PATH=$PATH:/home/erlang/bin

否则提示rebar找不到到escript。

在源码目录,运行make,没有任何提示,所以不用这种方法,

将include下的mysql.hrl拷贝到src目录下,然后“erlc *.erl”,得到beam文件

在源码mysql目录下创建ebin目录,将这些beam文件拷贝到ebin下。

最后的目录结构式这样的

mysql

  |---ebin

  |---src

  |---include

 

4、将整个mysql目录移到erlang中,假设你的erlang放在/home/erlang下

将mysql移到/home/erlang/lib/erlang/lib下,而不是直接放在/home/erlang/lib下。

 

可以了,打开erlang的终端测试一下

mysql:start_link(conn, "数据库IP或域名", 3306, "root", "密码", "数据库名称", undefined, utf8). {data, Result} = mysql:fetch(conn, <<"select * from t_users">>). Rows = mysql:get_result_rows(Result).

 

5、去除不必要的打印信息

增加一个log函数,只容许error级别的打印,其他的都不打了。

log(Module, Line, Level, FormatFun) ->     case Level of     error ->         {Format, Arguments} = FormatFun(),         io:format("~w:~b: "++ Format ++ "~n", [Module, Line] ++ Arguments);     _ -> o    end .

mysql:start_link(conn, "数据库IP或域名", 3306, "root", "密码", "数据库名称", fun log/4, utf8).

 

希望上面的内容对你有用,减少不必要的时间浪费:)

erlang连接mysql [转]

标签:

原文地址:http://www.cnblogs.com/jluzhsai/p/4417868.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!