Mercurial > hg > ltpda
annotate m-toolbox/classes/+utils/@mysql/execute.m @ 37:a4b7ceae0403 database-connection-manager
Show backtrace on unit test errors
author | Daniele Nicolodi <nicolodi@science.unitn.it> |
---|---|
date | Mon, 05 Dec 2011 16:20:06 +0100 |
parents | 2b57573b11c7 |
children |
rev | line source |
---|---|
6
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
1 function varargout = execute(conn, query, varargin) |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
2 % EXECUTE Execute the given QUERY with optional parameters VARARGIN |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
3 % substituted for the '?' placeholders through connection CONN. In the |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
4 % case of data manupulation queries returns the update count. In case |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
5 % of data retrival queries returns a 2D cell array with the query |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
6 % results and optionally a cell array with column names. |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
7 % |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
8 % CALL: |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
9 % |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
10 % [rows] = utils.mysql.execute(conn, query, varargin) |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
11 % [rows, names] = utils.mysql.execute(conn, query, varargin) |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
12 % |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
13 % PARAMETERS: |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
14 % |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
15 % conn - an object implementing the java.sql.Connection interface |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
16 % query - SQL query string. ? are substituted with PARAMS values |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
17 % varargin - query parameters |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
18 % |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
19 % RETURNS: |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
20 % |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
21 % rows - update count in the case of data manipulation queries |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
22 % or 2D cell array with query resutls in the case of |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
23 % data retrival queries |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
24 % names - names of the columns in the result set |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
25 % |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
26 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
27 % check parameters |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
28 if nargin < 2 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
29 error('### incorrect usage'); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
30 end |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
31 if ~isa(conn, 'java.sql.Connection') |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
32 error('### invalid connection'); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
33 end |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
34 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
35 % build query |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
36 stmt = conn.prepareStatement(query); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
37 for kk = 1:numel(varargin) |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
38 stmt.setObject(kk, matlab2sql(varargin{kk})); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
39 end |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
40 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
41 % execute query |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
42 rv = stmt.execute(); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
43 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
44 switch rv |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
45 case 0 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
46 % we have an update count |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
47 varargout{1} = stmt.getUpdateCount(); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
48 case 1 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
49 % we have a result set |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
50 rs = stmt.getResultSet(); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
51 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
52 % get results into a cell array |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
53 md = rs.getMetaData(); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
54 nc = md.getColumnCount(); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
55 row = 1; |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
56 rows = {}; |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
57 while rs.next() |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
58 for kk = 1:nc |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
59 % convert to matlab objects |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
60 rows{row, kk} = java2matlab(rs.getObject(kk)); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
61 end |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
62 row = row + 1; |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
63 end |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
64 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
65 % get column names |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
66 names = cell(1, nc); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
67 for kk = 1:nc |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
68 names{kk} = char(md.getColumnName(kk)); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
69 end |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
70 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
71 % assign output |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
72 switch nargout |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
73 case 0 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
74 varargout{1} = rows; |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
75 case 1 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
76 varargout{1} = rows; |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
77 case 2 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
78 varargout{1} = names; |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
79 varargout{2} = rows; |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
80 otherwise |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
81 error('### too many output arguments'); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
82 end |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
83 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
84 otherwise |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
85 erorr('### error'); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
86 end |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
87 end |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
88 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
89 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
90 function val = matlab2sql(val) |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
91 switch class(val) |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
92 case 'char' |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
93 % matlab converts length one strings to the wrong java type |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
94 val = java.lang.String(val); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
95 case 'time' |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
96 % convert time objects to strings |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
97 val = val.format('yyyy-mm-dd HH:MM:SS', 'UTC'); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
98 end |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
99 end |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
100 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
101 |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
102 function val = java2matlab(val) |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
103 % matlab converts all base types. just add a conversion for datetime columns |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
104 switch class(val) |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
105 case 'java.sql.Timestamp' |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
106 val = time(plist('time', char(val), 'timezone', 'UTC')); |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
107 end |
2b57573b11c7
Add utils.mysql.execute
Daniele Nicolodi <nicolodi@science.unitn.it>
parents:
diff
changeset
|
108 end |