一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - JDBC程序更新數據庫中記錄的方法

JDBC程序更新數據庫中記錄的方法

2020-01-12 14:31康kang JAVA教程

這篇文章主要介紹了JDBC程序更新數據庫中記錄的方法,涉及Java基于JDBC操作數據庫的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下

本文實例講述了JDBC程序更新數據庫中記錄的方法。分享給大家供大家參考,具體如下:

使用JDBC程序(Eclipse、MyEclipse)更新數據庫(MySql)中的記錄時可以只修改記錄的一個字段或幾個字段,具體方法為可以加入如下被注釋代碼(前提是修改之前可以從數據庫中得到該條記錄)以user表為例

?
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
public class UserDaoJdbcImpl implements UserDao {
 public void update(User u) {
 Connection conn = null;
 PreparedStatement ps = null;
 ResultSet rs = null;
 try {
  conn = JdbcUtils.getConnection();
  String sql = "update user set name = ?, birthday = ?, money = ? where id=?";
  ps = conn.prepareStatement(sql);
  // 首先得到該記錄
  User user = getUserById(u.getId());
  // 判斷字段是否需要修改
  if (u.getName() == null) {
  u.setName(user.getName());
  }
  if (u.getBirthday() == null) {
  u.setBirthday(user.getBirthday());
  }
  if (u.getMoney() == 0) {
  u.setMoney(user.getMoney());
  }
  ps.setString(1, u.getName());
  ps.setDate(2, new java.sql.Date(u.getBirthday().getTime()));
  ps.setDouble(3, u.getMoney());
  ps.setInt(4, u.getId());
  int i = ps.executeUpdate();
  System.out.println("成功向user表中更新" + i + "條記錄");
 } catch (SQLException e) {
  e.printStackTrace();
 } finally {
  JdbcUtils.free(rs, ps, conn);
 }
 }
 public User getUserById(int id) {
 Connection conn = null;
 PreparedStatement ps = null;
 ResultSet rs = null;
 User user = null;
 try {
  conn = JdbcUtils.getConnection();
  String sql = "select * from user where id = ?";
  ps = conn.prepareStatement(sql);
  ps.setInt(1, id);
  rs = ps.executeQuery();
  if (rs.next()) {
  user = new User();
  user.setId(rs.getInt("id"));
  user.setName(rs.getString("name"));
  user.setBirthday(rs.getDate("birthday"));
  user.setMoney(rs.getDouble("money"));
  }
 } catch (SQLException e) {
  e.printStackTrace();
 } finally {
  JdbcUtils.free(rs, ps, conn);
 }
 return user;
 }
}

調用:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public static void main(String[] args) {
 UserDao ud = new UserDaoJdbcImpl();
 User user = new User();
 user.setId(9);
 user.setName("老師");//只修改name和birthday屬性
 Date d = null;
 try {
  SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  d = sdf.parse("1999-9-14");
 } catch (ParseException e) {
  e.printStackTrace();
 }
 user.setBirthday(d);
 //user.setMoney(1234);不修改money屬性
 ud.update(user);
}

希望本文所述對大家Java程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 被强迫调教的高辣小说 | 免费91麻豆精品国产自产在线观看 | 特黄特a级特别特级特毛片 特黄a级三级三级野战 | 水多多www视频在线观看高清 | 亚洲精品国产成人99久久 | 久久国产综合精品欧美 | 久久成人a毛片免费观看网站 | 亚洲日本va午夜中文字幕 | 色婷婷久久综合中文久久一本` | 5g在线观看 | 歪歪漫画a漫入口 | 动漫a级片| 美国一级大黄大色毛片 | 国内精品 大秀视频 日韩精品 | 欧美理论片手机在线观看片免费 | 女烈受刑重口小说 | 美人老师沦为 | 久久精品麻豆国产天美传媒果冻 | 欧美日韩亚洲高清不卡一区二区三区 | 5月色婷婷| 欧洲网色偷偷亚洲男人的天堂 | 成人免费视频一区二区三区 | 暖暖的视频完整视频韩国免费 | 日韩欧美推理片免费看完整版 | 午夜精品久久久久久中宇 | 日日网| girlfriend动漫在线播放 | 狠狠色婷婷丁香六月 | futa巨大好爽好长 | 手机看片国产免费久久网 | 欧美日韩国产精品va | 精品卡1卡2卡三卡免费网站 | 精品一区二区三区免费站 | av91在线 | 69成人网 | 美女扒开腿让男生桶爽漫画 | 国产欧美日韩图片一区二区 | 幻女free性俄罗斯第一次摘花 | 亚洲国产无线码在线观看 | 日韩欧美在线视频一区二区 | 日噜噜|