【省略了配置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 |
之前安裝過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測試
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("成功修改");
結果如圖所示: