程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA綜合教程 >> Java數據庫連接技術——JDBC,java數據庫連接jdbc

Java數據庫連接技術——JDBC,java數據庫連接jdbc

編輯:JAVA綜合教程

Java數據庫連接技術——JDBC,java數據庫連接jdbc


  大家好,今天我們學習了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();
            }
        }
    }
}
                                                                                                                                                                                

 

  以上是我的個人觀點,有異議的地方望大家指正,共同學習,共同進步!

  

  

 

 

 

 

  

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved