zoukankan      html  css  js  c++  java
  • Java学习笔记之:Java JDBC

    一、介绍

      JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用java语言编写的类和接口组成。

      有了JDBC,向各种关系数据发送SQL语句就是一件很容易的事。换言之,有了JDBC API,就不必为访问Sybase数据库专门写一个程序,为访问Oracle数据库又专门写一个程序,或为访问Informix数据库又编写另一个程序等等,程序员只需用JDBC API写一个程序就够了,它可向相应数据库发送SQL调用。

    /**
     * JDBC:文件驱动 
     * 1.引入jar包 ojdbc.jar 在工程的目录下创建一个lib文件夹用来存放jar包
     * 在ojdbc14.jar这个文件上右键==>build Path==> add to build Path 
     * 2.编写DB类 
     * a.加载驱动 
     * b.设置参数url user pwd 
     * c.连接数据库
     * d.编写sql语句
     * e.编译sql语句 
     * f.如果存在条件
     * 设置条件后执行sql语句,如果没有条件直接执行sql语句 g.如果是增删改 那么sql执行结束 如果是查询,遍历结果集 f.关闭数据库
     * 
     * 
     *
     */

    二、初始化

    1.配置连接:在引入了ojdbc14.jar包之后,我们需要使用Class.forName方法加载驱动,然后通过DriverManager.getConnection来获取连接

        // 初始化
        public void init() {
            // 不同的数据库有不同的驱动
            String driverName = "oracle.jdbc.driver.OracleDriver";
            String url = "jdbc:oracle:thin:@192.168.1.150:1521:XE";
            String user = "hr";
            String password = "123456";
    
            try {
                // 加载驱动
                Class.forName(driverName);
                // 设置 配置数据
                // 1.url(数据看服务器的ip地址 数据库服务端口号 数据库实例)
                // 2.user
                // 3.password
                conn = DriverManager.getConnection(url, user, password);
                // 开始连接数据库
                System.out.println("数据库连接成功..");
            } catch (ClassNotFoundException e) {
                // TODO 自动生成的 catch 块
                e.printStackTrace();
            } catch (SQLException e) {
                // TODO 自动生成的 catch 块
                e.printStackTrace();
            }
    
        }

     2.初始化

        Connection conn = null;
    
        public static void main(String[] args) {
            DB db = new DB();
            db.init();
    } 

    三、操作

    如果我们需要操作数据,就需要一个容器来保存它,这里我们可以用javabean来保存他们。

    public class Student {
    
        private Integer id;
        private String name;
        private Integer age;
        private Integer agestart;
        private Integer ageend;
        public Integer getAgestart() {
            return agestart;
        }
    
        public void setAgestart(Integer agestart) {
            this.agestart = agestart;
        }
    
        public Integer getAgeend() {
            return ageend;
        }
    
        public void setAgeend(Integer ageend) {
            this.ageend = ageend;
        }
    
        public Student() {
            // TODO 自动生成的构造函数存根
        }
    
        public Student(Integer id, String name, Integer age) {
            super();
            this.id = id;
            this.name = name;
            this.age = age;
        }
    
        public Integer getId() {
            return id;
        }
    
        public void setId(Integer id) {
            this.id = id;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public Integer getAge() {
            return age;
        }
    
        public void setAge(Integer age) {
            this.age = age;
        }
    }

    1.简单的查询

        public List<Student> select() throws SQLException {
    
            List<Student> list = new ArrayList<Student>();
            // *查询
            // 创建sql语句
            String sqlString = "select * from student";
            // 编译sql语句
            // 执行查询
            pst = conn.prepareStatement(sqlString);
            rSet = pst.executeQuery();
            // 遍历结果
            Student student = null;
            while (rSet.next()) {
                // System.out.print(rSet.getInt(1) + "	");
                // System.out.print(rSet.getString(2) + "	");
                // System.out.print(rSet.getInt(3) + "	");
                // System.out.print("
    ");
                student = new Student();
                student.setId(rSet.getInt(1));
                student.setName(rSet.getString(2));
                student.setAge(rSet.getInt(3));
                list.add(student);
    
            }
    
            return list;
        }
    List<Student> students = null;
    students = db.select();
     for (int i = 0; i < students.size(); i++) {
                 System.out.print(students.get(i).getId() + "	");
                 System.out.print(students.get(i).getName() + "	");
                 System.out.print(students.get(i).getAge());
                 System.out.println();
                 }

    结果:

    2.条件查询

        public List<Student> selectByStu(int age) throws SQLException {
            List<Student> students = new ArrayList<Student>();
            String sql = "select * from student where sage=? ";
    
            pst = conn.prepareStatement(sql);
            // 设置条件(相对于条件查询)
            pst.setInt(1, age);
            rSet = pst.executeQuery();
            Student student = null;
            while (rSet.next()) {
                student = new Student();
                student.setId(rSet.getInt(1));
                student.setName(rSet.getString(2));
                student.setAge(rSet.getInt(3));
                students.add(student);
            }
    
            return students;
        }
        students = db.selectByStu(20);
            for (int i = 0; i < students.size(); i++) {
                 System.out.print(students.get(i).getId() + "	");
                 System.out.print(students.get(i).getName() + "	");
                 System.out.print(students.get(i).getAge());
                 System.out.println();
                 }

    结果:

    3.多个条件查询

        public List<Student> selectByCondition(Student e) throws SQLException {
            List<Student> students = new ArrayList<Student>();
            String sql = "select * from student where sage>? and sage<? ";
            pst = conn.prepareStatement(sql);
            pst.setInt(1, e.getAgestart());
            pst.setInt(2, e.getAgeend());
            rSet = pst.executeQuery();
            Student student = null;
            while (rSet.next()) {
                student = new Student();
                student.setId(rSet.getInt(1));
                student.setName(rSet.getString(2));
                student.setAge(rSet.getInt(3));
                students.add(student);
            }
            return students;
        }
                 Student stu = new Student();
                 stu.setAgestart(20);
                 stu.setAgeend(22);
                 students = db.selectByCondition(stu);
    
                 for (int i = 0; i < students.size(); i++) {
                 System.out.print(students.get(i).getId() + "	");
                 System.out.print(students.get(i).getName() + "	");
                 System.out.print(students.get(i).getAge());
                 System.out.println();
                 }

    4.添加数据

        public void save(Student student) throws SQLException {
            String sql = "insert into student values (?,?,?,null,null,null,null,null)";
    
            pst = conn.prepareStatement(sql);
            pst.setInt(1, student.getId());
            pst.setString(2, student.getName());
            pst.setInt(3, student.getAge());
            pst.executeUpdate();
            System.out.println("添加成功");
        }

    5.更新数据

        public void update(Student student) throws SQLException {
            String sql = "update student set sage=? where sid=?";
    
            pst = conn.prepareStatement(sql);
            pst.setInt(1, student.getAge());
            pst.setInt(2, student.getId());
            pst.executeUpdate();
            System.out.println("更新成功");
        }

    6.删除数据

    public void delete(Integer id) throws SQLException {
            String sql = "delete student where sid=?";
    
            pst = conn.prepareStatement(sql);
            pst.setInt(1, id);
            pst.executeUpdate();
            System.out.println("删除成功");
        }

    7.分页

        public List<Student> findByPage(int start, int end) throws SQLException {
            List<Student> students = new ArrayList<Student>();
            String sql = "select s_.* from(select  s.*,rownum rn from (select * from student order by sid) s where rownum<=?) s_  where rn>?";
    
            pst = conn.prepareStatement(sql);
            pst.setInt(1, end);
            pst.setInt(2, start);
            rSet = pst.executeQuery();
            Student student = null;
            while (rSet.next()) {
                student = new Student();
                student.setId(rSet.getInt(1));
                student.setName(rSet.getString(2));
                student.setAge(rSet.getInt(3));
                students.add(student);
            }
            return students;
        }

     四、笔记

    package com.hgd.study.JDBC;
    
    import java.net.CookieHandler;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.util.ArrayList;
    import java.util.List;
    
    public class DB {
        Connection conn = null;
        PreparedStatement pst;
        ResultSet rSet;
    
        public static void main(String[] args) {
            DB db = new DB();
    
            List<Student> students = null;
            try {
                db.initConn();
                //students = db.select();
    
                //students = db.selectByStu(20);
    
                 Student stu = new Student();
                 stu.setAgestart(20);
                 stu.setAgeend(22);
                 students = db.selectByCondition(stu);
    
                 for (int i = 0; i < students.size(); i++) {
                 System.out.print(students.get(i).getId() + "	");
                 System.out.print(students.get(i).getName() + "	");
                 System.out.print(students.get(i).getAge());
                 System.out.println();
                 }
    
                // Student stu = new Student(123, "李四", 23);
                // db.save(stu);
    
                // Student stu=new Student();
                // stu.setId(10003);
                // stu.setAge(23);
                // db.update(stu);
    
                // db.delete(123);
    
                /*
                 * 事物: 1.原子性:每一个事物都是一个单独的操作 2.一致性:事物中的所有操作,只要成功全部成功,一旦失败全部失败
                 * 3.隔离性:事物中的操作之间没不会产生影响他们都是一个独立的操作 4.持久性:事物一旦成功将被永久写入数据库
                 */
                // conn.setAutoCommit(false);// 设置自动事物为false
                // conn.setSavepoint();// 设置事物的回滚点
                // conn.rollback();//事物回滚
                // conn.commit();//事物提交
                // db.setAutoCommit(false);
                // db.setSavepoint();
                // Student stu = new Student();
                // stu.setId(10003);
                // stu.setAge(0);
                // db.update(stu);
                // if (stu.getAge() <= 0) {
                // db.rollback();
                // System.out.println("取消了操作");
                // } else {
                // db.commit();
                // }
    
            } catch (Exception e) {
                // TODO 自动生成的 catch 块
                e.printStackTrace();
            } finally {
                try {
                    db.close();
                } catch (Exception e) {
                    // TODO 自动生成的 catch 块
                    e.printStackTrace();
                }
            }
        }
    
        // 初始化
        public void init() {
            // 不同的数据库有不同的驱动
            String driverName = "oracle.jdbc.driver.OracleDriver";
            String url = "jdbc:oracle:thin:@192.168.1.150:1521:XE";
            String user = "hr";
            String password = "123456";
    
            try {
                // 加载驱动
                Class.forName(driverName);
                // 设置 配置数据
                // 1.url(数据看服务器的ip地址 数据库服务端口号 数据库实例)
                // 2.user
                // 3.password
                conn = DriverManager.getConnection(url, user, password);
                // 开始连接数据库
                System.out.println("数据库连接成功..");
            } catch (ClassNotFoundException e) {
                // TODO 自动生成的 catch 块
                e.printStackTrace();
            } catch (SQLException e) {
                // TODO 自动生成的 catch 块
                e.printStackTrace();
            }
    
        }
    
        public void initConn() throws Exception {
            if (conn == null || conn.isClosed()) {
                this.init();
            }
        }
    
        public void close() throws Exception {
            if (conn != null && !conn.isClosed()) {
                conn.close();
                conn = null;
    
            }
        }
    
        public void setAutoCommit(boolean fals) throws Exception {
            if (conn != null && !conn.isClosed()) {
                conn.setAutoCommit(fals);
            }
        }
    
        public void setSavepoint() throws Exception {
            if (conn != null && !conn.isClosed()) {
                conn.setSavepoint();
            }
        }
    
        public void rollback() throws Exception {
            if (conn != null && !conn.isClosed()) {
                conn.rollback();
            }
        }
    
        public void commit() throws Exception {
            if (conn != null && !conn.isClosed()) {
                conn.commit();
            }
        }
    
        // 简单查询
        public List<Student> select() throws SQLException {
    
            List<Student> list = new ArrayList<Student>();
            // *查询
            // 创建sql语句
            String sqlString = "select * from student";
            // 编译sql语句
            // 执行查询
            pst = conn.prepareStatement(sqlString);
            rSet = pst.executeQuery();
            // 遍历结果
            Student student = null;
            while (rSet.next()) {
                // System.out.print(rSet.getInt(1) + "	");
                // System.out.print(rSet.getString(2) + "	");
                // System.out.print(rSet.getInt(3) + "	");
                // System.out.print("
    ");
                student = new Student();
                student.setId(rSet.getInt(1));
                student.setName(rSet.getString(2));
                student.setAge(rSet.getInt(3));
                list.add(student);
    
            }
    
            return list;
        }
    
        // 条件查询
        public List<Student> selectByStu(int age) throws SQLException {
            List<Student> students = new ArrayList<Student>();
            String sql = "select * from student where sage=? ";
    
            pst = conn.prepareStatement(sql);
            // 设置条件(相对于条件查询)
            pst.setInt(1, age);
            rSet = pst.executeQuery();
            Student student = null;
            while (rSet.next()) {
                student = new Student();
                student.setId(rSet.getInt(1));
                student.setName(rSet.getString(2));
                student.setAge(rSet.getInt(3));
                students.add(student);
            }
    
            return students;
        }
    
        // 多个条件值查询
        public List<Student> selectByCondition(Student e) throws SQLException {
            List<Student> students = new ArrayList<Student>();
            String sql = "select * from student where sage>? and sage<? ";
            pst = conn.prepareStatement(sql);
            pst.setInt(1, e.getAgestart());
            pst.setInt(2, e.getAgeend());
            rSet = pst.executeQuery();
            Student student = null;
            while (rSet.next()) {
                student = new Student();
                student.setId(rSet.getInt(1));
                student.setName(rSet.getString(2));
                student.setAge(rSet.getInt(3));
                students.add(student);
            }
            return students;
        }
    
        // 添加数据
        public void save(Student student) throws SQLException {
            String sql = "insert into student values (?,?,?,null,null,null,null,null)";
    
            pst = conn.prepareStatement(sql);
            pst.setInt(1, student.getId());
            pst.setString(2, student.getName());
            pst.setInt(3, student.getAge());
            pst.executeUpdate();
            System.out.println("添加成功");
        }
    
        // 更新数据
        public void update(Student student) throws SQLException {
            String sql = "update student set sage=? where sid=?";
    
            pst = conn.prepareStatement(sql);
            pst.setInt(1, student.getAge());
            pst.setInt(2, student.getId());
            pst.executeUpdate();
            System.out.println("更新成功");
        }
    
        // 删除数据
        public void delete(Integer id) throws SQLException {
            String sql = "delete student where sid=?";
    
            pst = conn.prepareStatement(sql);
            pst.setInt(1, id);
            pst.executeUpdate();
            System.out.println("删除成功");
        }
    
        // 分页
        public List<Student> findByPage(int start, int end) throws SQLException {
            List<Student> students = new ArrayList<Student>();
            String sql = "select s_.* from(select  s.*,rownum rn from (select * from student order by sid) s where rownum<=?) s_  where rn>?";
    
            pst = conn.prepareStatement(sql);
            pst.setInt(1, end);
            pst.setInt(2, start);
            rSet = pst.executeQuery();
            Student student = null;
            while (rSet.next()) {
                student = new Student();
                student.setId(rSet.getInt(1));
                student.setName(rSet.getString(2));
                student.setAge(rSet.getInt(3));
                students.add(student);
            }
            return students;
        }
    
    }
    View Code
  • 相关阅读:
    PCB 规则引擎之脚本语言JavaScript应用评测
    PCB 挺有意思的基数排序----C#代码实现
    PCB NOSQL MongoDb MI流程指示数据存储结构
    PCB javascript解析Gerber274X格式实现方法
    PCB javascript解析钻孔(Excellon)格式实现方法
    PCB 围绕CAM自动化,打造PCB规则引擎
    PCB Genesis拼SET画工艺边 实现方法(一)
    约瑟夫环的三种解法
    Microsoft edge真香!
    商城规格参数
  • 原文地址:https://www.cnblogs.com/huguodong/p/5910859.html
Copyright © 2011-2022 走看看