JDBC定义:
    JDBC全称: Java DataBase Connectivity
      独立于特定数据管理系统, 通用的sql数据库存取和操作的公共接口, 是一种面向接口编程
    JDBC为访问不同的数据库提供了不同的途径

ojdbc6.jar是JDBC连接数据库所必需的一个驱动包, 这个驱动包里面的某些特定的方法实现了下面三个接口, 从而可以连接到数据库
      我们把这种可以实现这三个接口的jar称为数据库的驱动包

Connection接口是jdk中定义好的一个数据库连接的接口, 在javaAPI当中没有定义任何实现该接口的实现类, 这些实现类将会由数据库厂商提供, 同样Statement, ResultSet这两个接    口都是以这种形式来定义, 这样的编程模式成为面向接口编程

JDBC主要使用的一个类和三个接口:
    DriverManager:
        驱动程序管理类, 由这个类来获取Connection接口的实例

Connection: 获取数据库的连接, 设置自动提交方式, 获取Statement(包括其子类)对象
        prepareStatement(sql)-->返回用于执行sql语句的一个对象
        callableStatement-->返回执行存储过程的一个对象
        setAutoCommit(true)-->设置数据库提交方式(自动 / 手动)

Statement: 执行sql语句, 返回结果集
        返回boolean类型 prepareStatement.execute()-->用于执行存储过程和函数
        返回ResultSet prepareStatement.executeQuery()-->用于查询的语句
        返回int prepareStatement.executeUpdate()-->用于增, 删, 改的语句

批量处理:
            prepareStatement.addBatch()-->每次处理一条sql语句
            返回int[] prepareStatement.executeBatch()-->将一批命令提交给数据库去执行

以占位符的形式构建sql语句
            String sql = "select * from tablename t where t.id=? and t.name in (?,?,?)";
            prepareStatemenet.setInt(1, 24)
            prepareStatemenet.setString(2, "Tom");
            prepareStatemenet.setString(3, "Jack");
            prepareStatemenet.setString(4, "Kitty");
            prepareStatemenet.executeQuery();
            调用设置占位符参数方法, 需要传两个参数:
                第一个参数: 占位符索引值, 第几个 ? , 就写几, 从1开始数
                第二个参数: 占位符的值, 设置什么类型的参数, 就用什么类型的方法

ResultSet:
        由Statement执行查询sql之后返回的结果集
        返回boolean类型 next()-->判断结果集是否有下一行数据
        获取数据
            resultSet.getString()--->方法可以传字符串, 表示表中字段的名字, 也可以传整数, 表示第几列
            resultSet.getInt()
            resultSet.getDate()
            ...
        通过对各种方法的重写来获取结果集中的数据

java连接数据库的代码
    定义四个属性: username, password, url, driver

    private static final String USERNAME = "数据库登录名";
private static final String PASSWORD = "数据库登录密码";
private static final String URL = "jdbc:oracle:thin:@localhost:1521:xe";
private static final String DRIVERCLASSNAME = "oracle.jdbc.OracleDriver";

1, 类加载器去加载数据库的驱动程序

   Class.forName(dirver);
        2, 直接调用DriverManager的静态方法getConnection()获取连接
        Connection conn = DriverManager.getConnection(url, username, password);

0822JDBC--Java连接数据库的更多相关文章

  1. Java连接数据库的辣几句话

    Java连接数据库的辣几句话 1.java连接Oracle数据库 使用以下代码三个步骤: 1.下载ojdbc.jar包并导入项目中.附下载地址:http://download.csdn.net/det ...

  2. servlet中Java连接数据库后的基本操作

    servlet中Java连接数据库后的基本操作 在eclipse中新建一个工程:login 在Server中新建一个服务器,基本的操作不用说了,在前两天的笔记中可以找到; 需要知道数据库的用户名和密码 ...

  3. java连接数据库

    package com.shsxt.jdbcs; import java.sql.Connection; import java.sql.DriverManager; import java.sql. ...

  4. Java连接数据库的4中方式详解

    Java连接数据库的方式有多种:根据所需要的不同数据库驱动分,分为四种: 1:1类驱动.这就是JDBC-ODBC桥的方式. 但这种方式不适合程序的重用与维护,不推荐使用.需要数据库的ODBC驱动. 2 ...

  5. Java连接数据库 #06# SQL与代码分离(精化版本)

    索引 DAO层依赖关系草图 应用示例 接Java连接数据库#05#,对代码进行改进. DAO层依赖关系草图 应用示例(只需3步!) 1.首先定义接口类: package org.sample.shop ...

  6. Java连接数据库 #05# SQL与代码分离

    索引 读取html中的SQL语句 缺陷总结 在Java连接数据库 #04#里大概是这样放sql语句的: package org.sample.shop.db.queryrunner; import o ...

  7. java连接数据库(jdbc)调用配置文件

    各种语言都有自己所支持的配置文件,后缀名“.properties”结尾的就是其中之一. 在java连接数据库时,采取读取配置文件的方式,来获取数据库连接. 新建jdbc.properties文件,内容 ...

  8. Java连接数据库 #04# Apache Commons DbUtils

    索引 通过一个简单的调用看整体结构 Examples 修改JAVA连接数据库#03#中的代码 DbUtils并非是什么ORM框架,只是对原始的JDBC进行了一些封装,以便我们少写一些重复代码.就“用” ...

  9. JAVA连接数据库 #03# HikariCP

    索引 为什么用数据库连接池? HikariCP快速入门 依赖 简单的草稿程序 设置连接池参数(只列举常用的) MySQL配置 修改Java连接数据库#02#中的代码 测试 为什么用数据库连接池? 为什 ...

  10. Java连接数据库 #02# JDBC经典套路

    内容索引 LocalConnectionFactory.java LocalConnectionProxy.java ProfileDAO.java-2.0 ProfileDAOImpl.java-2 ...

随机推荐

  1. LightOJ 1306 - Solutions to an Equation 裸EXGCD

    本题是极其裸的EXGCD AX+BY+C=0 给你a b c 和x与y的区间范围,问你整数解有几组 作为EXGCD入门,题目比较简单 主要需要考虑区间范围的向上.向下取整,及正负符号的问题 问题是这正 ...

  2. ClassCastException: org.apache.tomcat.websocket.server.WsServerContainer cannot be cast to javax.websocket.server.ServerContainer

    21:09:22.221 [MessageBroker-3] INFO c.t.s.s.impl.StockNewsServiceImpl - [2017-12-16 21:09:22] execut ...

  3. [uva11137]立方数之和·简单dp

    小水题再来一发 给定一个正整数n<=1e4,求将n写成若干个正整数立方和的方法数 典型的多阶段模型 f[i][j]表示当前用到1~i的数,累计和为j的方案数. #include<cstdi ...

  4. 【bzoj1774-过路费】floyd+排序

    题意:n个点,m条双向边,每个点有权值c[i],每条边有权值a[i].d,一条路径的费用=每条边的权值和+各个点的权值的最大值,即sigma(a[i].d)+max(c[i]).q个询问,问x到y的最 ...

  5. bzoj 2258 splay

    类似于1014,用splay维护这个序列,维护每个节点为根的子树的hash值,对于一个询问二分答案判断就行了. 反思:询问的时候因为是原序列的x,y,所以开始的时候直接splay(x-1)了,后来发现 ...

  6. DesignPattern

    目录

  7. nsa工程式(fb.py): perl6调用并修改IP

    use v6; if (@*ARGS != 1) {say 'Use:scan.p6 ip';exit;} my $check_ip = @*ARGS[0]; $check_ip = '<val ...

  8. 盲注脚本2.基于bool

    盲注脚本2.基于bool #!/usr/bin/env python #encoding:utf-8 #by i3ekr #using # python sqlinject.py -D "数 ...

  9. ubuntu安装wifi

    因为需要测试app,但是自己本地是deepin.如果win下的话直接安装一个wifi万能管家啥的就完事儿了.可是这个是linux 有点不同.所以就进行百度学习了一波.特此分享. 需要用到的工具 hos ...

  10. Python3安装Celery模块后执行Celery命令报错

    1 Python3安装Celery模块后执行Celery命令报错 pip3 install celery # 安装正常,但是执行celery 命令的时候提示没有_ssl模块什么的 手动在Python解 ...