当前位置 : 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 删除记录