国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

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

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - java基于jdbc連接mysql數據庫功能實例詳解

java基于jdbc連接mysql數據庫功能實例詳解

2021-01-23 12:57偉雪無痕 Java教程

這篇文章主要介紹了java基于jdbc連接mysql數據庫功能,結合實例形式詳細分析了jdbc連接mysql數據庫的原理、步驟、實現方法及相關操作技巧,需要的朋友可以參考下

本文實例講述了java基于jdbc連接mysql數據庫的方法。分享給大家供大家參考,具體如下:

一、JDBC簡介

Java 數據庫連接,(Java Database Connectivity,簡稱JDBC)是Java語言中用來規范客戶端程序如何來訪問數據庫的應用程序接口,提供了諸如查詢和更新數據庫中數據的方法。JDBC也是Sun Microsystems的商標。它JDBC是面向關系型數據庫的。

1、JDBC架構:

JDBC API支持兩層和三層處理模型進行數據庫訪問,但在一般的JDBC體系結構由兩層組成:

JDBC API: 提供了應用程序對JDBC的管理連接;

JDBC Driver API: 支持JDBC管理到驅動器連接;

JDBC API的使用驅動程序管理器和數據庫特定的驅動程序提供透明的連接到異構數據庫;

JDBC驅動程序管理器可確保正確的驅動程序來訪問每個數據源,該驅動程序管理器能夠支持連接到多個異構數據庫的多個并發的驅動程序;

以下是結構圖,它顯示了驅動程序管理器方面的JDBC驅動程序和Java應用程序的位置:

java基于jdbc連接mysql數據庫功能實例詳解

2、常見的JDBC組件:

JDBC API提供了以下接口和類:

DriverManager: 這個類管理數據庫驅動程序的列表,內容是否符合從Java應用程序使用的通信子協議正確的數據庫驅動程序的連接請求,識別JDBC在一定子協議的第一個驅動器將被用來建立數據庫連接;

Driver: 此接口處理與數據庫服務器通信,很少直接與驅動程序對象,相反,使用DriverManager中的對象,它管理此類型的對象,它也抽象與驅動程序對象工作相關的詳細信息;

Connection : 此接口與接觸數據庫的所有方法,連接對象表示通信上下文,即,與數據庫中的所有的通信是通過唯一的連接對象;

Statement : 可以使用這個接口創建的對象的SQL語句提交到數據庫,一些派生的接口接受除執行存儲過程的參數;

ResultSet: 這些對象保存從數據庫后,執行使用Statement對象的SQL查詢中檢索數據,它作為一個迭代器,讓您可以通過移動它的數據;

SQLException: 這個類處理發生在一個數據庫應用程序的任何錯誤.

二、連接JDBC需要掌握的基本知識

1、數據庫的基本操作,

eg:Mysql的安裝和基本操作(insert,delete,update,query)

2、java開發工具的使用,

eg:Eclipse/MyEclipse (包括mysql-connector-java-5.0.3-bin.jar的導入)

三、JDBC的連接及代碼演示

1、JDBC連接工具類

1)、Configuration.java:可以從.xml文件中連接數據庫的配置信息,需要引入dom4j-1.6.1.jar包

?
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
package cn.java.jdbc;
import java.io.InputStream;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class Configuration {
  private String url;
  private String driver;
  private String username;
  private String password;
  public Configuration() {
  }
  public Configuration(String url, String driver, String username,
      String password) {
    super();
    this.url = url;
    this.driver = driver;
    this.username = username;
    this.password = password;
  }
  public static Configuration getConfigure()
  {
    try {
      InputStream in = Configuration.class.getResourceAsStream("/db.xml");
      if (null!=in) {
        return load(in);
      }
      return null;
    } catch (DocumentException e) {
      e.printStackTrace();
      return null;
    }
  }
  private static Configuration load(InputStream in) throws DocumentException {
    SAXReader reader = new SAXReader();
    Document doc = reader.read(in);
    Element jdbc = doc.getRootElement();
    String url = jdbc.element("url").getText();
    String driver = jdbc.element("driver").getText();
    String username = jdbc.element("username").getText();
    String password = jdbc.element("password").getText();
    Configuration cfg = new Configuration(url, driver, username, password);
    return cfg;
  }
  public String getUrl() {
    return url;
  }
  public void setUrl(String url) {
    this.url = url;
  }
  public String getDriver() {
    return driver;
  }
  public void setDriver(String driver) {
    this.driver = driver;
  }
  public String getUsername() {
    return username;
  }
  public void setUsername(String username) {
    this.username = username;
  }
  public String getPassword() {
    return password;
  }
  public void setPassword(String password) {
    this.password = password;
  }
}

2)、db.xml:保存數據庫的配置信息

?
1
2
3
4
5
6
7
<?xml version="1.0" encoding="UTF-8"?>
<jdbc>
<url>jdbc:mysql://localhost:3306/test</url>
<driver>com.mysql.jdbc.Driver</driver>
<username>root</username>
<password></password>
</jdbc>

3)、ConnectionFactory.java:JDBC連接工廠方法之一

?
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
package cn.java.jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class ConnectionFactory {
  private static ConnectionFactory connectionFactory=null;
  private static Configuration config=Configuration.getConfigure();
  private ConnectionFactory()
  {
    try {
    Class.forName(config.getDriver());
  } catch (ClassNotFoundException e) {
  }
  }
  public Connection getConnection() throws SQLException
  {
    Connection con=null;
    try {
      con=DriverManager.getConnection(config.getUrl(), config.getUsername(), config.getPassword());
      return con;
    }finally{
//     if (null != con) {
//       con.close();
//     }
    }
  }
  public static ConnectionFactory getInstance()
  {
    if (null==connectionFactory) {
      connectionFactory=new ConnectionFactory();
    }
    return connectionFactory;
  }
}

4)、ConnectionFactory2.java:JDBC連接工廠方法之二

?
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
package cn.java.jdbc;
import java.sql.Connection;
import java.sql.SQLException;
import javax.sql.DataSource;
import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;
public class ConnectionFactory2 {
  private DataSource ds ;
  private static ConnectionFactory2 connectionFactory2 = null;
  private ConnectionFactory2() {
    MysqlDataSource myDS = new MysqlDataSource() ;
    myDS.setServerName("localhost");
    myDS.setDatabaseName("test");
    myDS.setPort(3306) ;
    myDS.setUser("root");
    myDS.setCharacterEncoding("utf-8");
    myDS.setPassword("");
    this.ds = myDS ;
  }
  public Connection getConnection() throws SQLException {
    Connection conn = null;
    try {
      conn = ds.getConnection() ;
      conn.setAutoCommit(false);
      return conn;
    } catch (SQLException e) {
      if (null != conn) {
        conn.close();
      }
      throw e;
    }
  }
  public static ConnectionFactory2 getInstance() {
    if (null == connectionFactory2) {
      connectionFactory2 = new ConnectionFactory2();
    }
    return connectionFactory2;
  }
}

5)、User.java:定義數據庫表user中的id和name的bean類,其中id是自動增長的

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
package cn.java.jdbc;
public class User {
  private int id;
  private String name;
  public User() {
  }
  public User(int id, String name) {
    this.id = id;
    this.name = name;
  }
  public int getId() {
    return id;
  }
  public void setId(int id) {
    this.id = id;
  }
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
}

6)、UserDao.java:user表的操作類,實現了insert、delete、update、query等方法

?
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
package cn.java.jdbc;
import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
public class UserDao {
  private PreparedStatement st = null;
  private ResultSet rs = null;
  public UserDao() {
  }
  public void insert( Connection con,String name) throws SQLException,IOException {
    String sql="insert into user(name) values(?) ";
    try{
      st=con.prepareStatement(sql);
      st.setString(1, name);
      st.executeUpdate();
    }finally{
      if (null!=st) {
        st.close();
      }
    }
  }
  public void delete(Connection con,int id) throws SQLException,IOException {
    String sql="delete from user where id=?";
    try{
      st=con.prepareStatement(sql);
      st.setInt(1, id);
      st.executeUpdate();
    }finally{
      if (null!=st) {
        st.close();
      }
    }
  }
  public void update( Connection con,int id,String name) throws SQLException,IOException {
    String sql="update user set name=? where id=?";
    try{
      st=con.prepareStatement(sql);
      st.setString(1, name);
      st.setInt(2, id);
      st.executeUpdate();
    }finally{
      if (null!=st) {
        st.close();
      }
    }
  }
  public User query(Connection con,int index) throws SQLException,IOException{
    User user=new User();
    String sql="select * from user where id=?";
    try{
      st=con.prepareStatement(sql);
      st.setInt(1, index);
      rs=st.executeQuery();
      while (rs.next()) {
        user.setId(rs.getInt(1));
        user.setName(rs.getString(2));
        break;
      }
    }finally{
      if (null!=rs) {
        rs.close();
      }
      if (null!=st) {
        st.close();
      }
    }
    return user;
  }
  public List<User> queryAll(Connection con) throws SQLException,IOException {
    List<User> list=new ArrayList<>();
    String sql="select * from user";
    try {
      st=con.prepareStatement(sql);
      rs=st.executeQuery();
      while (rs.next()) {
        User user=new User();
        user.setId(rs.getInt(1));
        user.setName(rs.getString(2));
        list.add(user);
      }
    }finally{
      if (null!=rs) {
        rs.close();
      }
      if (null!=st) {
        st.close();
      }
    }
    return list;
  }
}

2、JDBC連接的測試類

1)、TestJdbc.java:數據庫測試類

?
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
package cn.java.jdbc;
import java.io.IOException;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
public class TestJdbc {
  public static void main(String[] args) {
    Connection con=null;
    try {
      con=(Connection) ConnectionFactory.getInstance().getConnection();
      UserDao userDao=new UserDao();
      //con=(Connection) ConnectionFactory2.getInstance().getConnection();
      if (null!=con) {
        System.out.println("Link JDBC SUCESS");
        //userDao.insert(con, "zhangsir");
        //userDao.delete(con, 4);
        //userDao.update(con, 1, "david");
        List<User> list=userDao.queryAll(con);
        for (User user : list) {
          System.out.println("id="+user.getId()+" name="+user.getName());
        }
      }
    } catch (SQLException e) {
      e.printStackTrace();
    } catch (IOException e) {
    e.printStackTrace();
    }finally{
      if (null!=con) {
        try {
          con.close();
        } catch (SQLException e) {
        }
      }
    }
  }
}

三、JDBC連接總結

JDBC操作的基本步驟是:

1、創建Connection對象,傳入SQL查詢命令字符串;
2、獲取PreparedStatement對象:通過Connection對象傳入SQL查詢命令獲取;
3、獲取ResultSet:對PreparedStatement執行executeUpdate()或者executeQurey()獲取;
4、依次關閉打開的對象:先后關閉ResultSet、PreparedStatement和Connection對象.

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

原文鏈接:http://blog.csdn.net/j086924/article/details/51546876

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品综合 | 日本在线免费 | 精精国产xxxx视频在线 | 最新中文字幕 | 久久在线视频 | 亚洲 欧美 日韩 在线 | 亚洲毛片网站 | 国产成人精品一区二区 | 欧美日韩亚洲一区二区 | 亚洲视频一区二区三区 | 国产小视频在线 | 一区二区三区中文 | 国产一区二区三区四 | 91免费在线视频 | 久久精品国产欧美亚洲人人爽 | 性色浪潮| 免费又黄又爽又色的视频 | 亚洲国产网站 | 精品国偷自产国产一区 | 国产精品久久久久久吹潮 | 一区二区日韩精品 | 亚洲国产成人av好男人在线观看 | a视频在线观看免费 | 在线播放亚洲 | 日韩中文在线视频 | 久久成人精品 | 日本色综合 | 精品欧美乱码久久久久久 | 亚洲男人在线 | 免费污网址 | 羞羞视频网| 精品美女久久久 | 97人人看 | 亚洲二区在线 | 在线色网站 | 日本久久久久久久久久 | 国产一区二区精品在线观看 | 久久久久久亚洲 | 欧美精品在线一区二区三区 | 天天操网 | 中文字幕日韩欧美 |