forked from jkvor/emysql
-
Notifications
You must be signed in to change notification settings - Fork 208
/
g_rows_as_json.erl
87 lines (71 loc) · 2.58 KB
/
g_rows_as_json.erl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
% ------------------------------------------------------------------------
% Emysql: sample for accessing rows as json
% M. Dorner <[email protected]>
% 17 Jun 2013
% ------------------------------------------------------------------------
%
% This sample does the same as the previous samples but converts row data to erlang representation of JSON.
% For actual JSON string use jsx (https://github.com/talentdeficit/jsx) or jiffy (https://github.com/davisp/jiffy).
%
% ------------------------------------------------------------------------
%
% Create local mysql database (or re-use the one made for a_hello):
%
% $ mysql ...
% mysql> create database hello_database;
% mysql> use hello_database;
% mysql> create table hello_table (hello_text char(20));
% mysql> grant all privileges on hello_database.* to hello_username@localhost identified by 'hello_password';
% mysql> quit
%
% On *nix build and run using the batch a_hello in folder samples/:
%
% $ ./g_rows_as_json
%
% - or -
%
% Make emysql and start this sample directly, along these lines:
%
% $ cd Emysql
% $ make
% $ cd samples
% $ erlc g_rows_as_json.erl
% $ erl -pa ../ebin -s g_rows_as_json run -s init stop -noshell
%
% ------------------------------------------------------------------------
%
% Expected Output:
%
% ...
% ... many PROGRESS REPORT lines ...
% ...
%
% JSON: [[{<<"hello_text">>,<<"Hello World!">>}]]
%
% ------------------------------------------------------------------------
-module(g_rows_as_json).
-export([run/0]).
run() ->
application:start(sasl),
crypto:start(),
application:start(emysql),
emysql:add_pool(hello_pool, [{size,1},
{user,"hello_username"},
{password,"hello_password"},
{database,"hello_database"},
{encoding,utf8}]),
emysql:execute(hello_pool,
<<"INSERT INTO hello_table SET hello_text = 'Hello World!'">>),
Result = emysql:execute(hello_pool, <<"SELECT * from hello_table">>),
%% -------------------------------------------------------------------
%% JSON Fetch: 2
%% - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
JSON = emysql:as_json(Result),
%% -------------------------------------------------------------------
io:format("~n~s~n", [string:chars($-,72)]),
%% -------------------------------------------------------------------
%% JSON Use : 3
%% - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
io:format("JSON: ~p~n", [JSON]),
%% -------------------------------------------------------------------
ok.