大家好,今天我們學習了Java如何連接數據庫。之前學過.net語言的數據庫操作,感覺就是一通百通,大同小異。
JDBC是Java數據庫連接技術的簡稱,提供連接各種常用數據庫的能力。
JDBC API (主要功能:與數據庫建立連接、執行語句、處理結果):
提供者:Sun公司
內容:供程序員調用的接口與類,集成在java.sql和javax.sql(後面的x是extend,擴展的意思)。如:
DriverManager類(管理各種不同的JDBC驅動),
Connection接口(連接數據、傳送數據),
statement接口(執行SQL語句),
ResultSet接口(根據statement返回的結果集,來處理結果)。
編寫步驟:
1.加載JDBC驅動;
2.創建數據庫連接對象;
3.創建命令對象statement,來執行SQL語句並返回結果集;
4.ResultSet通過返回的結果集,來處理結果;
5.關閉數據庫連接,釋放資源。
舉一個驗證用戶登錄的例子吧:
package jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Scanner;
/**
* JDBC連接數據庫.java
* 2017-1-6 上午11:14:48
* John
*/
public class Test {
public static void main(String[] args) {
Scanner input=new Scanner(System.in);
System.out.println("請輸入用戶名:");
String username=input.next();
System.out.println("請輸入密碼:");
String userpwd=input.next();
//1.加載JDBC驅動
try {
Class.forName("com.mysql.jdbc.Driver");//MySQL使用的驅動器
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//2.創建數據庫連接對象
Connection conn=null;
Statement stat=null;
ResultSet rs=null;
try {
//mysql連接URL編寫格式為:
//jdbc:mysql://主機名稱:連接端口/數據庫名稱
String url="jdbc:mysql://localhost:3306/Pet";
conn=DriverManager.getConnection(url, "root","123456");
//3.創建命令對象statement
stat=conn.createStatement();
//4.執行命令,並返回結果集
String sql="select count(1) as cnt from users where UserName='"+username+"' and userpwd='"+userpwd+"'";
rs=stat.executeQuery(sql);
while(rs.next()){
int count=rs.getInt("cnt");
if (count==1) {
System.out.println("登錄成功!");
}else {
System.out.println("登錄失敗!");
}
}
} catch (SQLException e) { //此處記住要對異常進行處理
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
//5.關閉數據庫連接
try {
conn.close();
stat.close();
rs=null;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
以上是我的個人觀點,有異議的地方望大家指正,共同學習,共同進步!