- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章java 使用策略模式操作JDBC数据库由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
java 使用策略模式操作JDBC数据库 。
1:构造一个操作数据库的工具类,可以获得连接和释放连接 。
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
public
class
DBUtil {
private
static
Connection conn =
null
;
static
{
//静态初始块
try
{
Class.forName(
"com.mysql.jdbc.Driver"
);
conn = DriverManager.getConnection(
"jdbc:mysql://127.0.0.1:3306/test"
,
"root"
,
"064319"
); //初始化获取连接
}
catch
(ClassNotFoundException e) {
e.printStackTrace();
}
catch
(SQLException e) {
e.printStackTrace();
}
}
/**
* 释放连接
* @param rs
* @param psmt
* @param conn
* @throws SQLException
*/
public
static
void
closeAll(ResultSet rs, PreparedStatement psmt, Connection conn)
throws
SQLException {
if
(rs !=
null
) {
rs.close();
}
if
(psmt !=
null
) {
psmt.close();
}
if
(conn !=
null
) {
conn.close();
}
}
/**
* 获取连接
* @return
*/
public
static
Connection getConnection() {
return
conn;
}
/**
* 根据表的名字来获得表的列信息
* @param tableName
*/
public
static
void
getTableColumnInfoByTableName(String tableName) {
Connection conn = getConnection();
ResultSet rs =
null
;
PreparedStatement psmt =
null
;
String sql =
"select * from "
+ tableName;
try
{
psmt = conn.prepareStatement(sql);
rs = psmt.executeQuery();
ResultSetMetaData resultSetMetaData = rs.getMetaData();
for
(
int
i =
1
; i<= resultSetMetaData.getColumnCount(); i++) {
System.out.println(resultSetMetaData.getColumnName(i));
}
}
catch
(SQLException e) {
e.printStackTrace();
}
finally
{
try
{
closeAll(rs, psmt, conn);
}
catch
(SQLException e) {
e.printStackTrace();
}
}
}
/**
* 根据表的名字来获得表的信息
* @param tableName
*/
public
static
void
getTableInfoByTableName(String tableName) {
Connection conn = getConnection();
PreparedStatement psmt =
null
;
ResultSet rs =
null
;
String sql =
"select * from "
+ tableName;
try
{
psmt = conn.prepareStatement(sql);
rs = psmt.executeQuery();
while
(rs.next()) {
ResultSetMetaData resultSetMetaData = rs.getMetaData();
for
(
int
i =
1
; i<= resultSetMetaData.getColumnCount(); i++) {
if
(i < resultSetMetaData.getColumnCount()) {
System.out.print(rs.getObject(resultSetMetaData.getColumnName(i)) +
", "
);
}
else
{
System.out.print(rs.getObject(resultSetMetaData.getColumnName(i)));
}
}
System.out.println();
}
}
catch
(SQLException e) {
e.printStackTrace();
}
finally
{
try
{
closeAll(rs, psmt, conn);
}
catch
(SQLException e) {
e.printStackTrace();
}
}
}
}
|
2:构造一个操作数据库的BaseDao类 。
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
public
class
BaseDao {
/**
* 根据一些参数来保存相应的对象
* @param sql 要执行的sql语句
* @param params 为sql语句中相应的参数赋值
* @return
*/
protected
boolean
saveOrUpdate(String sql, Object[] params) {
Connection conn =
null
;
PreparedStatement psmt =
null
;
boolean
flag =
false
;
conn = DBUtil.getConnection();
if
(conn !=
null
) {
try
{
psmt = conn.prepareStatement(sql);
for
(
int
i =
1
; i <= params.length; i++) {
psmt.setObject(i, params[i-
1
]);
}
if
(psmt.executeUpdate() >
0
) {
flag =
true
;
}
}
catch
(SQLException e) {
e.printStackTrace();
}
finally
{
try
{
DBUtil.closeAll(
null
, psmt, conn);
}
catch
(SQLException e) {
e.printStackTrace();
}
}
}
return
flag;
}
/**
* 根据一定的参数获得某个具体的对象
* @param sql 要执行的sql语句
* @param params 为sql语句中相应的参数赋值
* @return
*/
public
Object queryForObject(String sql, Object[] params, RowMapForObject rowMapForObject) {
Connection conn =
null
;
PreparedStatement psmt =
null
;
conn = DBUtil.getConnection();
Object obj =
null
;
ResultSet rs =
null
;
if
(conn !=
null
) {
try
{
psmt = conn.prepareStatement(sql);
if
(params !=
null
&& params.length >
0
) {
for
(
int
i =
1
; i <= params.length; i++) {
psmt.setObject(i, params[i -
1
]);
}
}
rs = psmt.executeQuery();
obj = rowMapForObject.rowMapForObject(rs);
}
catch
(SQLException e) {
e.printStackTrace();
}
finally
{
try
{
DBUtil.closeAll(
null
, psmt, conn);
}
catch
(SQLException e) {
e.printStackTrace();
}
}
}
return
obj;
}
/**
* 根据相应的参数获得查询的结果集
* @param sql
* @param params
* @return
*/
public
List queryForList(String sql, Object[] params, RowMapForList rowMapForList) {
Connection conn =
null
;
PreparedStatement psmt =
null
;
conn = DBUtil.getConnection();
List list =
null
;
ResultSet rs =
null
;
if
(conn !=
null
) {
try
{
psmt = conn.prepareStatement(sql);
if
(params !=
null
&& params.length >
0
) {
for
(
int
i =
1
; i <= params.length; i++) {
psmt.setObject(i, params[i -
1
]);
}
}
rs = psmt.executeQuery(sql);
list =
new
ArrayList();
list = rowMapForList.rowMapForList(rs);
}
catch
(SQLException e) {
e.printStackTrace();
}
finally
{
try
{
DBUtil.closeAll(
null
, psmt, conn);
}
catch
(SQLException e) {
e.printStackTrace();
}
}
}
return
list;
}
}
|
3:新建一个StudentDao类,该类继承自BaseDao,实现对Student的管理 。
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
|
public
class
StudentDao
extends
BaseDao {
/**
* 保存一个Student的信息
*/
public
boolean
saveStudent(Student student) {
String sql =
"insert into t_student(name, age) values(?, ?)"
;
Object[] params =
new
Object[]{student.getName(), student.getAge()};
return
super
.saveOrUpdate(sql, params);
}
/**
* 根据id获得一个Student的信息
* @param id
* @return
*/
public
Student getStudentById(
long
id) {
String sql =
"select * from t_student where id=?"
;
Object[] params =
new
Object[]{id};
return
(Student)
super
.queryForObject(sql, params,
new
RowMapForObject() {
public
Object rowMapForObject(ResultSet rs) {
Student student =
null
;
try
{
if
(rs !=
null
&& rs.next()) {
student =
new
Student();
student.setAge(rs.getInt(Student.AGE));
student.setId(rs.getLong(Student.ID));
student.setName(rs.getString(Student.NAME));
}
}
catch
(SQLException e) {
e.printStackTrace();
}
return
student;
}
});
}
/**
* 获得所有Student的信息
* @return
*/
public
List getStudentAll() {
String sql =
"select * from t_student"
;
List list =
super
.queryForList(sql,
null
,
new
RowMapForList() {
@Override
public
List rowMapForList(ResultSet rs) {
List list =
null
;
try
{
if
(rs !=
null
) {
list =
new
ArrayList();
while
(rs.next()) {
Student student =
new
Student();
student.setId(rs.getLong(
"id"
));
student.setAge(rs.getInt(
"age"
));
student.setName(rs.getString(
"name"
));
list.add(student);
}
}
}
catch
(SQLException e) {
e.printStackTrace();
}
return
list;
}
});
return
list;
}
}
|
如有疑问请留言或者到本站社区交流讨论,大家共同进步,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持! 。
原文链接:http://blog.csdn.net/woshisap/article/details/7192822 。
最后此篇关于java 使用策略模式操作JDBC数据库的文章就讲到这里了,如果你想了解更多关于java 使用策略模式操作JDBC数据库的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
对此感到疯狂,真的缺少一些东西。 我有webpack 4.6.0,webpack-cli ^ 2.1.2,所以是最新的。 在文档(https://webpack.js.org/concepts/mod
object Host "os.google.com" { import "windows" address = "linux.google.com" groups = ["linux"] } obj
每当我安装我的应用程序时,我都可以将数据库从 Assets 文件夹复制到 /data/data/packagename/databases/ .到此为止,应用程序工作得很好。 但 10 或 15 秒后
我在 cc 模式缓冲区中使用 hideshow.el 来折叠我不查看的文件部分。 如果能够在 XML 文档中做到这一点就好了。我使用 emacs 22.2.1 和内置的 sgml-mode 进行 xm
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 我们不允许提出有关书籍、工具、软件库等方面的建议的问题。您可以编辑问题,以便用事实和引用来回答它。 关闭
根据java: public Scanner useDelimiter(String pattern) Sets this scanner's delimiting pattern to a patt
我读过一些关于 PRG 模式以及它如何防止用户重新提交表单的文章。比如this post有一张不错的图: 我能理解为什么在收到 2xx 后用户刷新页面时不会发生表单提交。但我仍然想知道: (1) 如果
看看下面的图片,您可能会清楚地看到这一点。 那么如何在带有其他一些 View 的简单屏幕中实现没有任何弹出/对话框/模式的微调器日期选择器? 我在整个网络上进行了谷歌搜索,但没有找到与之相关的任何合适
我不知道该怎么做,我一直遇到问题。 以下是代码: rows = int(input()) for i in range(1,rows): for j in range(1,i+1):
我想为重写创建一个正则表达式。 将所有请求重写为 index.php(不需要匹配),它不是以/api 开头,或者不是以('.html',或'.js'或'.css'或'.png'结束) 我的例子还是这样
MVC模式代表 Model-View-Controller(模型-视图-控制器) 模式 MVC模式用于应用程序的分层开发 Model(模型) - 模型代表一个存取数据的对象或 JAVA PO
我想为组织模式创建一个 RDF 模式世界。您可能知道,组织模式文档基于层次结构大纲,其中标题是主要的分组实体。 * March auxiliary :PROPERTIES: :HLEVEL: 1 :E
我正在编写一个可以从文件中读取 JSON 数据的软件。该文件包含“person”——一个值为对象数组的对象。我打算使用 JSON 模式验证库来验证内容,而不是自己编写代码。符合代表以下数据的 JSON
假设我有 4 张 table 人 公司 团体 和 账单 现在bills/persons和bills/companys和bills/groups之间是多对多的关系。 我看到了 4 种可能的 sql 模式
假设您有这样的文档: doc1: id:1 text: ... references: Journal1, 2013, pag 123 references: Journal2, 2014,
我有这个架构。它检查评论,目前工作正常。 var schema = { id: '', type: 'object', additionalProperties: false, pro
这可能很简单,但有人可以解释为什么以下模式匹配不明智吗?它说其他规则,例如1, 0, _ 永远不会匹配。 let matchTest(n : int) = let ran = new Rand
我有以下选择序列作为 XML 模式的一部分。理想情况下,我想要一个序列: 来自 my:namespace 的元素必须严格解析。 来自任何其他命名空间的元素,不包括 ##targetNamespace和
我希望编写一个 json 模式来涵盖这个(简化的)示例 { "errorMessage": "", "nbRunningQueries": 0, "isError": Fals
首先,我是 f# 的新手,所以也许答案很明显,但我没有看到。所以我有一些带有 id 和值的元组。我知道我正在寻找的 id,我想从我传入的三个元组中选择正确的元组。我打算用两个 match 语句来做到这
我是一名优秀的程序员,十分优秀!