zoukankan      html  css  js  c++  java
  • Java数据库编程JDBC

    一、定义

    JDBC,Java DataBase Connectivity。

    是Java运行平台核心类库中的一部分,提供了访问数据库的API,由一些Java类和接口组成。

    在Java中可以使用JDBC实现对数据库中表记录的查询,修改,和删除等操作

    JDBC技术在数据库开发中占有很重要的地位。JDBC操作不同的数据库仅仅是连接方式上的差异。

    使用JDBC的应用程序一旦和数据库建立连接,就可以使用JDBC提供的API操作数据库

    操作步骤:

    1.与一个数据库建立连接

    2.向已连接的数据库发送SQL语句

    3.处理SQL语句返回的结果

    二、连接数据库

    1.建立JDBC-ODBC桥接器

    JDBC使用java.lang包中的Class类建立JDBC-ODBC桥接器。Class类通过调用它的静态方法forName加载sun.jdbc.odbc包中的jdbcOdbcDriver类建立JDBC-ODBC桥接器。

    建立桥接器时可能发生异常,因此,必须捕获这个异常。

    建立桥接器的代码:

    1 try{Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
    2 }
    3 catch(ClassNotFoundException e){
    4         System.out.println(e);   
    5 }

    三、建立连接

    在编写的连接数据库代码中不会出现数据库的名称,只能出现数据源的名字。

    首先使用java.sql包中的Connection类声明一个对象,然后使用DriverManager类调用它的静态方法getConnection创建这个连接对象

    1 Connection con = DriverManager.getConnection("jdbc:odbc:数据源名字","login name","passworf");

    如果没有为数据源设置login name和password 那么连接形式如下:

    1 1 Connection con = DriverManager.getConnection("jdbc:odbc:数据源名字","","");

    为了能和数据源star交换数据,在建立链接时应捕获SQLException异常

    1 try{Connection con = DriverManager.getConnection("jdbc:odbc:数据源名字","","");}
    2 catch(SQLException e){}

    应用程序一旦和某个数据源建立连接,就可以通过SQL语句和该数据源所指定的数据库中的表交互信息,比如增上改查。

    四、示例

     1 package org.mobiletrain.jdbc1;
     2 
     3 import java.sql.Connection;
     4 import java.sql.DriverManager;
     5 import java.sql.ResultSet;
     6 import java.sql.SQLException;
     7 import java.sql.Statement;
     8 import java.util.ArrayList;
     9 import java.util.List;
    10 
    11 /**
    12  * 本程序执行用java代码查询数据库,返回结果。存入List集合中
    13  * 
    14  * @author Administrator
    15  * 
    16  */
    17 public class Demo01_JDBC {
    18 
    19     public static void main(String[] args) {
    20         // step1:加载驱动程序
    21         /**
    22          * 1.需要将数据库的驱动包(接口的实现类程序),复制到工程中:WebContent/WEB_INF/lib
    23          * 
    24          * 2.jar包上右键build path
    25          * 
    26          * 3.通过反射,让当前的类识别驱动程序
    27          */
    28         Connection conn = null;// 连接数据库的对象
    29         Statement statement = null;// 传送sql语句并执行的对象
    30         ResultSet rSet = null;// 存储查询结果的对象
    31         try {
    32             Class.forName("org.sqlite.JDBC");// 通过反射,获取驱动程序
    33             // step2:提供链接的参数
    34             String url = "jdbc:sqlite:/c:/pro/test.db";
    35             // step3:动DriverManager中获取连接对象Connection
    36             conn = DriverManager.getConnection(url);
    37             // step4:准备sql语句,并且创建传送器对象
    38             String sql = "select id,name,age,sex,classno from student";
    39             statement = conn.createStatement();
    40             // step5:传送sql语句,并执行
    41             rSet = statement.executeQuery(sql);// 表示传送器传送sql语句,并执行
    42             // step6:处理数据
    43             List<Student> list = new ArrayList<Student>();// 创建容器,用于存储学生对象,数据来源于结果集
    44             // 循环获取结果集中的数据
    45             while (rSet.next()) {
    46                 // 需要从结果集中取数据
    47                 int id = rSet.getInt(1);// 获取查询到的第一列的内容
    48                 String name = rSet.getString("name");// 通过字段名称获取内容
    49                 int age = rSet.getInt("age");
    50                 String sex = rSet.getString("sex");
    51                 int classno = rSet.getInt("classno");
    52                 // 根据字段的数值,创建学生对象
    53                 Student stu = new Student(id, name, age, sex, classno);
    54                 // 将学生对象存入lsit集合
    55                 list.add(stu);
    56             }
              //循环输出查询到的结果
    57 for (Student stu : list) { 58 System.out.println(stu.getId() + "\t" + stu.getName() + "\t" 59 + stu.getAge() + "\t" + stu.getSex() + "\t" 60 + stu.getClassno()); 61 } 62 } catch (ClassNotFoundException e) { 63 e.printStackTrace(); 64 } catch (SQLException e) { 65 e.printStackTrace(); 66 } finally { 67 // step7:关闭资源 68 // conn,statement,resultset 69 if (rSet != null) { 70 try { 71 rSet.close(); 72 } catch (SQLException e) { 73 // TODO Auto-generated catch block 74 e.printStackTrace(); 75 } 76 } 77 if (statement != null) { 78 try { 79 statement.close(); 80 } catch (SQLException e) { 81 // TODO Auto-generated catch block 82 e.printStackTrace(); 83 } 84 } 85 if (conn != null) { 86 try { 87 conn.close(); 88 } catch (SQLException e) { 89 e.printStackTrace(); 90 } 91 } 92 } 93 94 } 95 96 }

    作者:听着music睡

    出处:http://www.cnblogs.com/xqxacm/

    Android交流群:38197636

    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

  • 相关阅读:
    PAT-1020 Tree Traversals
    PAT- 1014 Waiting in Line
    Python稀疏矩阵运算
    阿里云Hadoop集群DataNode连接不上NameNode
    运行python “没有那个文件或目录3” 或 “/usr/local/bin/python3^M: bad interpreter: 没有那个文件或目录” 错误
    #!/usr/bin/python3 和 #!/usr/bin/env python3的区别
    VBoxManage安装
    Redhat终端中文乱码解决
    Redhat更换yum源
    Redhat乱码
  • 原文地址:https://www.cnblogs.com/xqxacm/p/4750271.html
Copyright © 2011-2022 走看看