zoukankan      html  css  js  c++  java
  • JDBC第一部分

    ##JDBC

       **概念:Java DataBase Connectivity

          补充:定义了操作所有关系型数据库的规则(接口)。各个数据库厂商去实现这套接口,提供数据库驱动jar包。我们可以使用这套接口编程,真正执行代码的是数据库驱动中的实现类。

       2. 快速入门:

           * 步骤:
             1. 导入驱动jar包 mysql-connector-java-5.1.37-bin.jar
               1.复制mysql-connector-java-5.1.37-bin.jar到项目的libs目录下
               2.右键-->Add As Library
              2. 注册驱动
                3. 获取数据库连接对象 Connection
                4. 定义sql
                5. 获取执行sql语句的对象 Statement
                6. 执行sql,接受返回结果
                7. 处理结果
                8. 释放资源

       3.插入新数据:insert into 表名 values(“”);

       4.删除表中部分数据:delete from 表名 where id=名称;

       5.建表。

       6.resultset应用实例:

              

    package demo;
    
    import java.sql.*;
    
    public class JDBCDemo05 {
        public static void main(String[] args) {
            Connection conn=null;
            Statement stat=null;
            ResultSet rs=null;
            try {
                Class.forName("com.mysql.jdbc.Driver");
                String url="jdbc:mysql://localhost:3309/db2";
                conn= DriverManager.getConnection(url,"root","hxj980417");
                stat=conn.createStatement();
                String sql="select * from account";
                rs=stat.executeQuery(sql);
                while (rs.next()){//遍历查询语句
                    int id=rs.getInt(1);//查询列数,有列数获得数据
                    String name=rs.getString("name");
                    double balance=rs.getDouble(3);
                    System.out.println(id+"	"+name+"	"+balance+"	");
                }
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }finally {
                try {
                    rs.close();
                } catch (SQLException throwables) {
                    throwables.printStackTrace();
                }
                try {
                    stat.close();
                } catch (SQLException throwables) {
                    throwables.printStackTrace();
                }
                try {
                    conn.close();
                } catch (SQLException throwables) {
                    throwables.printStackTrace();
                }
            }
        }
    }

     练习:* 定义一个方法,查询emp表的数据将其封装为对象,然后装载集合,返回。

        

    package lianxi;
    
    import java.sql.*;
    import java.util.ArrayList;
    import java.util.List;
    
    public class demo {
    
        public static void findall(){
            Connection conn=null;
            Statement stat=null;
            ResultSet rs=null;
            List<Emp> list=new ArrayList<Emp>();
    
            try {
                Class.forName("com.mysql.jdbc.Driver");
                String url="jdbc:mysql://localhost:3309/db2";
                conn= DriverManager.getConnection(url,"root","hxj980417");
                stat=conn.createStatement();
                String sql="select * from emp";
                rs=stat.executeQuery(sql);
                while(rs.next()) {
                    Emp emp = new Emp();
                    emp.setId(rs.getInt(1));
                    emp.setEname(rs.getString("ename"));
                    emp.setJob_id(rs.getInt(3));
                    emp.setMgr(rs.getInt("mgr"));
                    emp.setJoindate(rs.getDate("joindate"));
                    emp.setSalary(rs.getDouble("salary"));
                    emp.setBonus(rs.getDouble("bonus"));
                    emp.setDept_id(rs.getInt("dept_id"));
                    list.add(emp);
                }
                for (Emp emp : list) {
                    System.out.println(emp);
                }
    
    
    
    
    
    
    
    
    
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }finally {
                if(rs!=null){
                    try {
                        rs.close();
                    } catch (SQLException throwables) {
                        throwables.printStackTrace();
                    }
                }
                if(stat!=null){
                    try {
                        stat.close();
                    } catch (SQLException throwables) {
                        throwables.printStackTrace();
                    }
                }
                if(conn!=null){
                    try {
                        conn.close();
                    } catch (SQLException throwables) {
                        throwables.printStackTrace();
                    }
                }
            }
    
    
            return;
        }
    
        public static void main(String[] args) {
            findall();
        }
    
    
    }

        

              

    
    
  • 相关阅读:
    基于jeesit下的工作流开发步骤
    SQL Server DBA SQL
    SQL Server 全文索引的硬伤
    SQL Server全文搜索
    数据库SQL优化大总结之 百万级数据库优化方案2
    百倍性能的PL/SQL优化案例(r11笔记第13天)
    SQL优化 · 经典案例 · 索引篇
    数据库SQL优化大总结之 百万级数据库优化方案
    pytest文档23-使用多个fixture和fixture直接互相调用
    pytest文档22-fixture详细介绍-作为参数传入,error和failed区别
  • 原文地址:https://www.cnblogs.com/resort-033/p/13193551.html
Copyright © 2011-2022 走看看