摘要:基本連接加載驅(qū)動建立連接其中這里的是自己創(chuàng)建的數(shù)據(jù)庫的名字是數(shù)據(jù)庫的管理員,是密碼下面直接連接數(shù)據(jù)庫,返回的是接口對象驅(qū)動名稱管理員和密碼都是加載驅(qū)動,但是會有異常,因此要避免異常獲得數(shù)據(jù)庫連接返回如果出現(xiàn)異常就會返回查詢數(shù)據(jù)首先根據(jù)所得的
基本連接
加載驅(qū)動: Class.forName(com.mysql.jdbc.Driver)
建立連接:Connection conn=DriverManager.getConnection(url,user,password)
其中url="jdbc:mysql://localhost:3306/java_demo",這里的java_demo是自己創(chuàng)建的數(shù)據(jù)庫的名字,user是mysql數(shù)據(jù)庫的管理員,password是密碼
下面直接連接數(shù)據(jù)庫,返回的是接口Connection對象
import java.sql.*; public static Connection getConnection() { Connection conn; String driver="com.mysql.jdbc.Driver"; //驅(qū)動名稱 String url="jdbc:mysql://localhost:3306/java_demo"; //url String user="root"; String password="root"; //管理員和密碼都是root try{ Class.forName(driver); //加載驅(qū)動,但是會有ClassNotFoundException異常,因此要避免異常 try{ conn = Dri verManager.getConnection(url, user, password); //獲得數(shù)據(jù)庫連接 return conn; //返回conn }catch(SQLException e) { e.printStackTrace(); } }catch (ClassNotFoundException e) { e.printStackTrace(); } return null; //如果出現(xiàn)異常就會返回null }查詢數(shù)據(jù)
首先根據(jù)所得的Connection對象創(chuàng)建Statement對象:Statement statement = connection.createStatement();
寫查詢語句:String sql="select * from student;" 這里是查詢所有student中的數(shù)據(jù),詳細內(nèi)容請看我的SQL干貨篇二
創(chuàng)建ResultSet對象存儲查詢結(jié)果:ResultSet res=statement.executeQuery(sql),詳細的內(nèi)容請看官方文檔ResultSet詳細用法
代碼
String sql="select * from student"; if(!conn.isClosed()) { Statement statement=conn.createStatement(); //這里的conn是上面連接數(shù)據(jù)庫的返回的Connection對象 ResultSet res=statement.executeQuery(sql); //執(zhí)行查詢,注意這里只能是executeQuery,Statement還有一些執(zhí)行mysql函數(shù),但是都不適合查詢,后面會詳細說 while(res.next()) //如果res結(jié)果中還有元素,那么返回true,否則返回的是false,用來判斷是否res中還有結(jié)果 { int id=res.getInt("id"); //得到id,這里的id是student表中的屬性名 對應的時int BigInt smallint..... String name=res.getString("name"); //得到姓名,對應的是mysql中的Char varChar類型 } }
當然上面只是對于基本的查詢數(shù)據(jù),在一些項目中根本用不到,因為不太靈活,上面的方法只適合全局查詢,并不適合在項目中根據(jù)條件查詢,下面介紹預編譯sql語句的接口PrepareStatement
首先編寫sql語句:sql="select * from student where id=?;";,這里的?表示一個占位,將條件在后面給出,但是這里一定要用?
創(chuàng)建對象:PrepareStatement pre=conn.preparestatement(sql);這里傳入?yún)?shù)sql
設(shè)置sql中的條件語句,填補占位?的值:pre.setInt(1,1);這里的SetInt設(shè)置id值的為1,因為這的id是int類型的,第一個參數(shù)是表示prepareindex,就是表示第一個占位?,當然第二個就是2,其中還有SetString(prepareindex String var),用來給定表中的char后者varchar類型的值
代碼:
if(!connection.isClosed()) { String sql="select * from course where id=?,name=?"; PreparedStatement preparedStatement=connection.prepareStatement(sql); preparedStatement.setInt(1,1); //給定條件中的值 prepareStatement.setString(2,"jack"); //為第二個?賦值 ResultSet res=preparedStatement.executeQuery(); //執(zhí)行查詢,返回的仍然是ResultSet對象 while(res.next()) { int id=res.getInt("id"); String name=res.getString("name"); System.out.println(id+"--"+name); } }插入數(shù)據(jù)
插入數(shù)據(jù)和上面的兩種方法基本是一樣的,不同的是mysql語句不同,還有的就是執(zhí)行語句改成了executeUpdate(sql),下面的代碼值給出了預編譯對象的方法,另外一種的方法使用范圍并不是很大,只要把上面的查詢改為executeUpdate即可
代碼:
public static int save(MemoBean memo) { String sql = "insert into student (username, title, content, momotype, memotime) values (?, ?, ?, ?, ?);"; Connection conn = getConnection(); PreparedStatement ps = null; try { ps = conn.prepareStatement(sql); ps.setString(1, memo.getUsername()); //設(shè)值value中的值 ps.setString(2, memo.getTitle()); ps.setString(3, memo.getContent()); ps.setString(4, memo.getMemotype()); ps.setString(5, memo.getMemotime()); return ps.executeUpdate(); //這里使用的是excuteUpdate } catch (SQLException e) { e.printStackTrace(); } finally { if (ps != null) { try { ps.close(); //關(guān)閉預編譯對象 } catch (SQLException e) { e.printStackTrace(); } } if (conn != null) { try { conn.close(); //關(guān)閉Connection對象 } catch (SQLException e) { e.printStackTrace(); } } } return -1; //沒有插入成功返回-1 }更新數(shù)據(jù)
這里是同樣的思路,和插入的基本是一樣,只需要改變sql語句即可
代碼:
public static int update(MemoBean memo) { String sql = "update student set username=?,title=?,content=?,momotype=?,memotime=? where id=?;";//查詢語句 Connection connection = getConnection(); PreparedStatement ps = null; try { ps = connection.prepareStatement(sql); ps.setString(1, memo.getUsername()); //設(shè)置條件語句中的值 ps.setString(2, memo.getTitle()); ps.setString(3, memo.getContent()); ps.setString(4, memo.getMemotype()); ps.setString(5, memo.getMemotime()); ps.setInt(6,memo.getId()); return ps.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } finally { if(ps!=null) { try { ps.close(); }catch (SQLException e) { e.printStackTrace(); } } if(connection!=null) { try { connection.close(); }catch (SQLException e) { e.printStackTrace(); } } } return -1; }最后說
歡迎瀏覽本人博客上面的代碼是從自己項目中截取的一部分代碼,這個是比較適用于面向?qū)ο蟮模彩亲畛S玫膶τ谀壳皝砜?/strong>
上面只是給出了查詢,插入,更新,因為這是最常用到的方法,其中還有創(chuàng)建表,刪除表,當然還有一些他的,這里的創(chuàng)建表直接用execute(sql)即可執(zhí)行,刪除表也是用execute(sql)即可執(zhí)行,當然如果要按照指定的條件刪除,那么可以使用預編譯對象執(zhí)行
其中executeUpdate(sql)適用于create,insert,update,delete,但是executeQuery(sql)適用于select,具體見官方文檔
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/67030.html
摘要:是訪問數(shù)據(jù)庫的標準規(guī)范。提供了一種基準據(jù)此可以構(gòu)建更高級的工具和接口,使數(shù)據(jù)庫開發(fā)人員能夠編寫數(shù)據(jù)庫應用程序。代碼如下工具類數(shù)據(jù)庫驅(qū)動注冊失敗提供獲取連接的方法獲得連接返回連接 本文為大家介紹 Java 如何使用JDBC 連接 MySQL 數(shù)據(jù)庫。 JDBC概述 JDBC(Java Data Base Connectivity,java數(shù)據(jù)庫連接)是一種用于執(zhí)行SQL語句的Java A...
摘要:是訪問數(shù)據(jù)庫的標準規(guī)范。提供了一種基準據(jù)此可以構(gòu)建更高級的工具和接口,使數(shù)據(jù)庫開發(fā)人員能夠編寫數(shù)據(jù)庫應用程序。代碼如下工具類數(shù)據(jù)庫驅(qū)動注冊失敗提供獲取連接的方法獲得連接返回連接 本文為大家介紹 Java 如何使用JDBC 連接 MySQL 數(shù)據(jù)庫。 JDBC概述 JDBC(Java Data Base Connectivity,java數(shù)據(jù)庫連接)是一種用于執(zhí)行SQL語句的Java A...
閱讀 1978·2021-11-22 15:33
閱讀 3009·2021-11-18 10:02
閱讀 2622·2021-11-08 13:16
閱讀 1633·2021-10-09 09:57
閱讀 1378·2021-09-30 09:47
閱讀 2013·2019-08-29 13:05
閱讀 3076·2019-08-29 12:46
閱讀 1013·2019-08-29 12:19