配置文件dbconfig.xml如下:
1
<config>
2
<dbinfo>
3
<url>jdbc:oracle:thin:@133.1.72.44:1521:test</url>
4
<user>test</user>
5
<pwd>test</pwd>
6
<connNumber>10</connNumber>
7
</dbinfo>
8
</config>
9data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
这样数据库连接类部分就完成了
下面写一个简单数据访问类,由Table、RowSet和Row三个类组成:
Table.java代码如下
1
package com.bat.afp.DAOComm;
2data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
3
import java.sql.Connection;
4
import java.sql.ResultSet;
5
import java.sql.ResultSetMetaData;
6
import java.sql.SQLException;
7
import java.sql.Statement;
8
import org.apache.log4j.Logger;
9data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
10data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
/**//**
11
* @author liuyf
12
*/
13data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class Table
{
14data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
15
private static final Logger logger = Logger.getLogger(Table.class);
16data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
17
private String tableName;
18data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
19data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Table(String name)
{
20
this.tableName = name;
21
}
22data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
23data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/**//**
24
* 根据条件查出该Table中的某些列
25
*
26
* @param sql
27
* @param cols
28
* @return
29
* @throws SQLException
30
*/
31data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private RowSet executeSQL(String criteria, String[] columns) throws SQLException
{
32
Connection conn = null;
33
Statement st = null;
34
ResultSet rs = null;
35
RowSet rows = new RowSet();
36data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
37
conn = DBUtil.getInstance().getConnection();
38
st = conn.createStatement();
39
StringBuffer buffer = new StringBuffer();
40data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < columns.length - 1; ++i)
{
41
buffer.append(columns[i]);
42
buffer.append(",");
43
}
44
buffer.append(columns[columns.length - 1]);
45
String column = buffer.toString();
46
rs = st.executeQuery("select " + column + " from " + tableName
47
+ (criteria == null ? "" : (" where " + criteria)));
48
int cols = columns.length;
49data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
while (rs.next())
{
50
Row row = new Row();
51data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < cols; ++i)
{
52
String name = columns[i];
53
String value = rs.getString(i + 1);
54
row.put(name, value);
55
}
56
rows.add(row);
57
}
58
}
59data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
finally
{
60data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
61
if (st != null)
62
st.close();
63data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
64
}
65data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
66
if (conn != null)
67
conn.close();
68data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
69
}
70
}
71
return rows;
72
}
73data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
74data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private RowSet executeSQL(String sql) throws SQLException
{
75
Connection conn = null;
76
Statement st = null;
77
ResultSet rs = null;
78
RowSet rows = new RowSet();
79data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
80
conn = DBUtil.getInstance().getConnection();
81
st = conn.createStatement();
82
rs = st.executeQuery(sql);
83
ResultSetMetaData rsmd = rs.getMetaData();
84
int cols = rsmd.getColumnCount();
85data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
while (rs.next())
{
86
Row row = new Row();
87data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < cols; ++i)
{
88
String name = rsmd.getColumnName(i + 1);
89
String value = rs.getString(i + 1);
90
row.put(name, value);
91
}
92
rows.add(row);
93
}
94
}
95data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
finally
{
96data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
97
if (st != null)
98
st.close();
99data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
100
}
101data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
102
if (conn != null)
103
conn.close();
104data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
105
}
106
}
107
return rows;
108
}
109data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
110data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private RowSet execute(String criteria) throws SQLException
{
111
Connection conn = null;
112
Statement st = null;
113
ResultSet rs = null;
114
RowSet rows = new RowSet();
115data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
116
conn = DBUtil.getInstance().getConnection();
117
st = conn.createStatement();
118
rs = st.executeQuery("select * from " + tableName
119
+ (criteria == null ? "" : (" where " + criteria)));
120
ResultSetMetaData rsmd = rs.getMetaData();
121
int cols = rsmd.getColumnCount();
122data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
while (rs.next())
{
123
Row row = new Row();
124data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < cols; ++i)
{
125
String name = rsmd.getColumnName(i + 1);
126
String value = rs.getString(i + 1);
127
row.put(name, value);
128
}
129
rows.add(row);
130
}
131
}
132data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
finally
{
133data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
134
if (st != null)
135
st.close();
136data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
137
}
138data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
139
if (conn != null)
140
conn.close();
141data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
142
}
143
}
144
return rows;
145
}
146data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
147data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/**//**
148
* 根据条件和给出的列名查询某些列的值
149
*
150
* @param criteria
151
* @param columns
152
* @return
153
* @throws SQLException
154
*/
155data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public RowSet getRowsOfSomeColumn(String criteria, String[] columns) throws SQLException
{
156
RowSet rs = executeSQL(criteria, columns);
157
return rs;
158
}
159data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
160data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/**//**
161
* 根据SQL语句查询并返回行集
162
*
163
* @param sql
164
* @return
165
* @throws SQLException
166
*/
167data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public RowSet getRowsBySql(String sql) throws SQLException
{
168
RowSet rs = executeSQL(sql);
169
return rs;
170
}
171data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
172data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/**//**
173
* 根据查询条件返回查到的第一行数据
174
*
175
* @param criteria
176
* @return
177
* @throws SQLException
178
*/
179data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Row getRow(String criteria) throws SQLException
{
180
RowSet rs = execute(criteria);
181
return rs.get(0);
182
}
183data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
184data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/**//**
185
* 根据查询条件返回行集 查询条件为sql语句中where后的条件 为null则无条件
186
*
187
* @param criteria
188
* @return
189
* @throws SQLException
190
*/
191data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public RowSet getRows(String criteria) throws SQLException
{
192
RowSet rs = execute(criteria);
193
return rs;
194
}
195data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
196data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public RowSet getRows(String columnName, String columnvalue) throws SQLException
{
197data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(columnName == null || columnName.equals(""))
{
198
return null;
199
}
200
String SQL = "select * from " + tableName + " where " + columnName + " = " + columnvalue;
201
RowSet rs = executeSQL(SQL);
202
return rs;
203
204
}
205data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
206data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/**//**
207
* 查询该Table的所有数据
208
*
209
* @return
210
* @throws SQLException
211
*/
212data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public RowSet getRows() throws SQLException
{
213
return getRows(null);
214
}
215data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
216data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/**//**
217
* 插入行
218
*
219
* @param row
220
* @throws SQLException
221
*/
222data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void putRow(Row row) throws SQLException
{
223
putRow(row, null);
224
}
225data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
226data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/**//**
227
* 插入行或更新行 如conditions为null,则为插入 如conditions不为null,则为更新
228
*
229
* @param row
230
* @param conditions
231
* @throws SQLException
232
*/
233data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void putRow(Row row, String conditions) throws SQLException
{
234
Connection conn = null;
235
Statement st = null;
236data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
237
String ss = "";
238data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (conditions == null)
{
239
ss = "INSERT INTO " + tableName + " VALUES (";
240data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < row.length(); ++i)
{
241
String v = row.get(i);
242
ss += "'" + v + "'";
243
if (i != row.length() - 1)
244
ss += ", ";
245
}
246
ss += ")";
247data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
248
ss = "UPDATE " + tableName + " SET ";
249data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < row.length(); ++i)
{
250
String k = row.getKey(i);
251
String v = row.get(i);
252
ss += k + "='" + v + "'";
253
if (i != row.length() - 1)
254
ss += ", ";
255
}
256
ss += " WHERE ";
257
ss += conditions;
258
}
259
logger.debug("Sql: " + ss);
260
conn = DBUtil.getInstance().getConnection();
261
st = conn.createStatement();
262
st.executeUpdate(ss);
263
}
264data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
finally
{
265data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
266
if (st != null)
267
st.close();
268data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
269
}
270data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
271
if (conn != null)
272
conn.close();
273data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
274
}
275
}
276
}
277data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
278data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void delRow(Row row) throws SQLException
{
279
Connection conn = null;
280
Statement st = null;
281data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
282
String ss = "";
283
ss = "delete from " + tableName + " where ";
284data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (int i = 0; i < row.length(); ++i)
{
285
String k = row.getKey(i);
286
String v = row.get(i);
287
ss += k + "='" + v + "'";
288
if (i != row.length() - 1)
289
ss += " and ";
290
}
291
conn = DBUtil.getInstance().getConnection();
292
st = conn.createStatement();
293
st.executeUpdate(ss);
294
}
295data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
finally
{
296data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
297
if (st != null)
298
st.close();
299data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
300
}
301data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
302
if (conn != null)
303
conn.close();
304data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
305
}
306
}
307
}
308data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
309data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void delRow(String conditions) throws SQLException
{
310
Connection conn = null;
311
Statement st = null;
312data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
313
String ss = "";
314
ss = "delete from " + tableName + " where ";
315
ss += conditions;
316
conn = DBUtil.getInstance().getConnection();
317
st = conn.createStatement();
318
st.executeUpdate(ss);
319data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (SQLException se)
{
320
se.printStackTrace();
321
}
322data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
finally
{
323data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
324
if (st != null)
325
st.close();
326data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
327
}
328data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
329
if (conn != null)
330
conn.close();
331data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
332
}
333
}
334
}