【DAY_02】IDEA環境下,使用JDBC鏈接MySQL數據庫,並進行增刪改查

【省略了配置tomcat和安裝IDEA的過程。】文章介紹瞭如何配置MySQL,如何經過JDBC鏈接數據庫,以及如何實現對數據庫的增刪改查。html

 

1、常見問題java

1.安裝mysql卡在最後start service一步:沒有刪除乾淨。刪除註冊表裏全部的mysql相關就能夠了。mysql

2.execute、executeUpdate、executeQuery三者的區別(及返回值)sql

executeQuery executeUpdate(String sql) execute(String sql)
執行SQL查詢,並返回ResultSet 對象 可執行增,刪,改,返回執行受到影響的行數 可執行任何SQL語句,返回一個布爾值,表示是否返回ResultSet
ResultSet rs = prst.executeQuery();
while (rs.next()) {...}
返回int

返回boolean

 

 

 

 

 

 

2、配置MySQL

之前安裝過MySQL的,再次安裝會遇到問題,這時候要看是否將MySQL刪除乾淨了。數據庫

1.卸載軟件,經過控制面板 2.刪除文件夾,在安裝目錄和C:\ProgramData隱藏文件夾下 3.刪除註冊表中的mysql相關內容tomcat

刪除HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Eventlog\Application\MySQL文件夾 刪除HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\Eventlog\Application\MySQL文件夾。 刪除HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application\MySQL的文件夾。maven

參考文章:http://www.javashuo.com/article/p-tqvbrpan-p.html測試

 

 

 

3、鏈接數據庫

1.項目目錄:網站

 

2.導入jar包,這裏我用的是mysql-connector-java-5.1.30.jar,在官網找半天沒有下載成功,最後是在這個網站下載的:http://maven.outofmemory.cn/mysql/mysql-connector-java/5.1.30/spa

 

3.鏈接數據庫

 

4.數據庫中建表 我在test數據庫中創建了student表格,隨意輸入了兩條信息做爲測試數據,以下圖:

 

5.測試代碼 DBTest中:

package com.dgd.test; import java.sql.*; /** * @author Dgd * @create 2017-10-16-21:25 * 測試數據庫 */
public class DBTest { //mysql驅動包名
    private static final String DRIVER_NAME = "com.mysql.jdbc.Driver"; //數據庫鏈接地址
    private static final String URL = "jdbc:mysql://localhost:3306/test"; //用戶名
    private static final String USER_NAME = "root"; //密碼
    private static final String PASSWORD = "123456"; public static void main(String[] args){ Connection connection = null; try { //加載mysql的驅動類
 Class.forName(DRIVER_NAME); //獲取數據庫鏈接
            connection = DriverManager.getConnection(URL, USER_NAME, PASSWORD); //mysql查詢語句
            String sql = "SELECT Sname FROM student"; PreparedStatement prst = connection.prepareStatement(sql); //結果集
            ResultSet rs = prst.executeQuery(); while (rs.next()) { System.out.println("用戶名:" + rs.getString("Sname")); } rs.close(); prst.close(); } catch (Exception e) { e.printStackTrace(); }finally { if (connection != null) { try { connection.close(); } catch (SQLException e) { e.printStackTrace(); } } } } }

 

 

6.測試成功,顯示測試用例

 

 

7.刪除一條數據

修改代碼以下:

 Statement stmt = connection.createStatement(); String sql = "DELETE FROM student WHERE Sname='李'";  //mysql查詢語句
 stmt.executeUpdate(sql); System.out.println("成功刪除"); ​ String sql2 = "SELECT * FROM student"; PreparedStatement prst = connection.prepareStatement(sql2); ResultSet rs = prst.executeQuery();//結果集  

 

結果以下:

 

 

7.添加多條數據

修改以前的代碼,變爲

String sql = "INSERT INTO student VALUES (111,'王'),(222,'錢')";

 

結果以下:

 

8.修改多條數據

修改代碼以下:

 Statement stmt = connection.createStatement(); //String sql = "DELETE FROM student WHERE Sname='李'"; //mysql查詢語句
            String sql = "UPDATE student SET Sname = CASE id " +
                    " WHEN 111 THEN '劉' " +
                    " WHEN 222 THEN '孫' " +
                    " END " +
                    " WHERE id IN (111,222) "; stmt.executeUpdate(sql); System.out.println("成功修改"); 

 

結果如圖所示:

相關文章
相關標籤/搜索