當前位置 : IT培訓網 > Java開發 > Java教程 > Java編程開發之數據庫查詢簡介

Java編程開發之數據庫查詢簡介

時間:2016-09-06 16:59:50??來源:Java培訓網??作者:IT培訓網??已有:名學員訪問該課程
利用Connection對象的createStatement方法建立Statement對象,利用Statement對象的executeQuery()方法執行SQL查詢語句進行查詢,返回結果集,再形如getXXX()的方法從結果集中讀取數據。經過這樣的一系列步驟就能實現對數據庫的查詢。

經過了一番努力,數據庫連接上了,也能訪問了,可如何查詢數據庫呢,查詢數據庫需要哪些語句呢,有沒有什么快捷的方式呢?今天IT培訓網小編就來為大家傳授這方面的課程吧,用心學習哦!

數據庫查詢簡介

利用Connection對象的createStatement方法建立Statement對象,利用Statement對象的executeQuery()方法執行SQL查詢語句進行查詢,返回結果集,再形如getXXX()的方法從結果集中讀取數據。經過這樣的一系列步驟就能實現對數據庫的查詢。

【例 13-9】Java應用程序訪問數據庫。應用程序打開考生信息表ksInfo,從中取出考生的各項信息。設考生信息數據庫的結構如下:

類型

字符串

字符串

整數

字符串

字符串

字段名

考號

姓名

成績

地址

簡歷

 

import java.awt.*;

import java.awt.event.*;

import javax.swing.*;

import java.util.*;

import java.sql.*;

public class Example10_9 extends JFrame implements ActionListener{

    public static Connection connectByJdbcodbc(String url, String username,String password){

        Connection con = null;

        try{

            Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");  //加載ODBC驅動程序

        }

        catch (Exception e){

            e.printStackTrace();

            return null; //加載失敗,連接不成功

        }

        try{

            con = DriverManager.getConnection(url, username, password);

        }

        catch (SQLException e){

            e.printStackTrace();

            return null; //連接失敗

        }

        return con; //連接成功

    }

    String title[] ={"考號", "姓名", "成績", "地址", "簡歷"};

    JTextField txtNo = new JTextField(8);

    JTextField txtName = new JTextField(10);

    JTextField txtScore = new JTextField(3);

    JTextField txtAddr = new JTextField(30);

    JTextArea txtresume = new JTextArea();

    JButton prev = new JButton("前一個");

    JButton next = new JButton("后一個");

    JButton first = new JButton("第一個");

    JButton last = new JButton("最后一個");

    Statement sql; //SQL語句對象

    ResultSet rs; //存放查詢結果對象

    Example10_9(Connection connect){

        super("考生信息查看窗口");

        setSize(450, 350);

        try{

            sql = connect.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);

            rs = sql.executeQuery("SELECT * FROM ksInfo");

            Container con = getContentPane();

            con.setLayout(new BorderLayout(0, 6); JPanel p[] = new JPanel[4];

            for (int i = 0; i < 4; i++){

                p[i] = new JPane(new FlowLayout(FlowLayout.LEFT, 8, 0));

                p[i].add(new JLabel(title[i]));

            }

            p[0].add(txtNo);

            p[1].add(txtName);

            p[2].add(txtScore);

            p[3].add(txtAddr);

            JPanel p1 = new JPane(new GridLayout94, 1, 0, 8));

            JScrollPane jsp = new JScrollPane(txtResume,

                JScrollPane.VERTICAL_SCROLLBAR_ALWAYS,

                JScrollPane.HORIZONTAL_SCROLLBAR_NEVER);

                jsp.setPreforredSize(new Dimension(300, 60);

            for (int i = 0; i < 4; i++){

                p1.add(p[i]);

            }

            JPanel p2 = new JPanel(new FlowLayout(FlowLayout.LEFT, 10, 0);

            p2.add(new JLabel(title[4]));

            p2.add(jsp);

            Jpanel p3 = new Jpanel();

            p3.add(prev);

            p3.add(next);

            p3.add(first);

            p3.add(last);

            prev.addActionListener(this);

            next.addActionListener(this);

            first.addActionListener(this);

            last.addActionlistener(this);

            rs.first();

            readRecord();

        }

        catch (Exception e){

            e.printStackTrace():

        }

        setVisible(ture);

    }

    public void modifyRecord(Connection connect){

        String stuNo = (String)JOptionPane.showInputDialog(null,

            "請輸入考生考號", "輸入考號對話框", JOptionPane.PLAIN_MESSAGE, null,

            null, "");

        try {

            sql = connect.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);

            rs = sql.executeQuery("SELECT * FROM ksInfo");

            Container con = getContentPane();

            con.setLayout(new Boarderlayout(0, 6));

            Jpanel p[] = new JPanel[4];

            for (int i = 0; i < ; i++){

                p[i] = new JPane(new FlowLayout(flowLayout.LEFT, 8, 0));

                p[i].add(new JLabel(title[i]));

            }

            p[0].add(txtNo);

            p[1].add(txtName);

            p[2].add(txtScore);

            p[3].add(txtAddr);

            Jpanel p1 = new Jpane(new GridLayout(4, 1, 0, 8));

            JScrollPane jsp = new JScrollPane(txtResume,

                JScrollPane.VERTICAL_SCROLLBAR_ALWAYS,

                JScrollPane.HORIZONTAL_SCROLLBAR_NEVER);

            jsp.setPreferredSize (new dimension(300, 60));

            for (int i = 0; i < 4; i++){

                p1.add(p[i]);

            }

            Jpanel p2 = new JPanel(new FlowLayout(FlowLayout.LEFT, 10, 0));

            p2.add(new JLableI(title[4]));

            p2.add(jsp);

            JPanel p3 = new JPanel();

            p3.add(prev);

            p3.add(next);

            p3.add(first);

            p3.add(last);

            prev.addActionListener(this);

            next.addActionListener(this);

            first.addActionListenerIthis);

            last.addActionListener(this);

            rs.first();

            readRecord();

        }

        catch (Exception e){

            e.printStackTrace();

        }

        setVisible(true);

    }

    boolean readRecord(){

        try{

            txtNo.setText(rs.getString("考號")); txtName.setText(rs.getString("姓名")); txtScore.setText(rs.getString("成績"));

            txtAddr.setText(rs.getString("地址")); txtResume.setText(rs.getString("簡歷"));

        }

        catch (SQLException e){

            e.printStackTrace(); return false;

        }

        return true;

    }

    public void actionPerformed(ActionEvent e){

        try{

            if (e.getSource() == prev)rs.previous();

            else if (e.getSource() == next)rs.next();

            else if (e.getSource() == first)rs.first();

            else if (e.getSource() == last)rs.last(); readRecord();

        }

        catch (Exception e2){}

    }

    public static void main(String args[]){

        connection connect = null;

        JFrame .setDefaultLookAndFeeDecorated(true);

        Font font = new Font("JFrame", Font.PLAIN, 14);

        if ((connect =connectByJdbcOdbc("jdbc:odbc:redsun", "xia", "1234")) == null){

            JOptionPane.showMessageDialog(null, "數據庫連接失敗!");

            System.exit ( - 1);

        }

        new Example10_9(connect); //創建對象

    }

}

關于Java數據庫查詢的方法和語句就介紹到這里了,希望大家用心學習,做好學習的計劃,雖然Java難度還可以,但不用心也是不行的。如果想要了解更高端的Java課程信息趕緊咨詢我校的老師吧!

頂一下
(0)
0%
踩一下
(0)
0%
------分隔線----------------------------
------分隔線----------------------------
Java教程
1、Java 概述
1.1 Java語言概述
1.2 Java虛擬機以及跨平臺原理
1.3 Java的主要就業方向
1.4 Java的不同版本
1.5 Java開發環境搭建
1.6 第一個Java程序示例
1.7 Java類和對象的概念
1.8 Java類庫及其組織結構
1.9 Java import
2、Java 語法基礎
2.1 Java數據類型以及變量的定義
2.2 Java數據類型轉換
2.3 Java運算符
2.4 Java流程控制
2.5 Java數組的定義和使用
2.6 Java字符串(String)
2.7 Java StringBuffer與StringBuider
2.8 強調一下編程風格
3、Java 類與對象
3.1 Java類的定義及其實例化
3.2 Java訪問修飾符
3.3 Java變量的作用域
3.4 Java this關鍵字詳解
3.5 Java方法重載
3.6 Java類的基本運行順序
3.7 Java包裝類、拆箱和裝箱詳解
3.8 再談Java包
3.9 源文件的聲明規則
4、Java 繼承和多態
4.1 繼承的概念與實現
4.2 Java super關鍵字
4.3 繼承中的方法的覆蓋和重載
4.4 多態和動態綁定
4.5 instanceof 運算符
4.6 多態對象的類型轉換
4.7 Java static關鍵字
4.8 Java final關鍵字
4.9 Java Object類
5、面向對象高級特性
5.1 Java內部類及其實例化
5.2 內部類的分類
5.3 抽象類的概念和使用
5.4 接口的概念和使用
5.5 接口和抽象類的區別
5.6 Java 泛型
5.7 泛型通配符和類型參數的范圍
6、異常處理
6.1 異常處理基礎
6.2 異常類型Java語言中常見的異常類型有哪些
6.3 未被捕獲的異常
6.4 try和catch的使用
6.5 多重catch語句的使用
6.6 try語句的嵌套
6.7 throw:異常的拋出
6.8 throws子句
6.9 finally塊
6.10 Java的內置異常
6.11 創建自己的異常子類
6.12 斷言
7、線程編程
7.1 線程的概念
7.2 Java線程模型
7.3 主線程
7.4 創建線程
7.5 創建多線程
7.6 isAlive()和join()的使用
7.7 線程優先級
7.8 線程同步
7.9 線程間通信
7.10 線程死鎖
7.11 線程的掛起、恢復和終止
8、輸入輸出(IO)操作
8.1 輸入輸出基本概念
8.2 面向字符的輸入流
8.3 面向字符的輸出流
8.4 面向字節的輸入輸出流
8.5 面向字節流的應用
8.6 文件與目錄管理
8.7 文件的隨機讀寫
8.8 文件的壓縮處理
9、常用類庫、向量與哈希
9.1 Java基礎類庫
9.2 Object類
9.3 Java語言包(java.lang)簡介
9.4 日期和時間類
9.5 向量及其應用
9.6 哈希表及其應用
10、圖形界面(GUI)設計
10.1 圖形界面設計基礎
10.2 框架窗口
10.3 標簽、按鈕和按鈕事件
10.4 面板
10.5 布局設計
10.6 文本框和文本區
10.7 文本框和文本區的輸入輸出
10.8 選擇框和單選按鈕
10.9 列表和組合框
10.10 菜單
10.11 對話框
10.12 滾動條
10.13 鼠標事件
10.14 鍵盤事件
11、圖形、圖像與多媒體
11.1 繪圖基礎
11.2 設置字型和顏色
11.3 繪圖模式
11.4 Graphics類的繪圖方法
11.5 Graphics2D類的繪圖方法
11.6 圖像處理基礎
11.7 圖像緩沖技術
11.8 多媒體基礎
12、網絡與數據庫編程
12.1 IP地址和InetAddress類
12.2 統一資源定位符
12.3 套接字(Socket)
12.4 數據庫連接
12.5 幾個重要的類和接口
12.6 數據庫查詢
12.7 數據庫更新
12.8 插入記錄
12.9 修改記錄
12.10 刪除記錄
激情色播