0822JDBC--Java连接数据库
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连接数据库的更多相关文章
- Java连接数据库的辣几句话
Java连接数据库的辣几句话 1.java连接Oracle数据库 使用以下代码三个步骤: 1.下载ojdbc.jar包并导入项目中.附下载地址:http://download.csdn.net/det ...
- servlet中Java连接数据库后的基本操作
servlet中Java连接数据库后的基本操作 在eclipse中新建一个工程:login 在Server中新建一个服务器,基本的操作不用说了,在前两天的笔记中可以找到; 需要知道数据库的用户名和密码 ...
- java连接数据库
package com.shsxt.jdbcs; import java.sql.Connection; import java.sql.DriverManager; import java.sql. ...
- Java连接数据库的4中方式详解
Java连接数据库的方式有多种:根据所需要的不同数据库驱动分,分为四种: 1:1类驱动.这就是JDBC-ODBC桥的方式. 但这种方式不适合程序的重用与维护,不推荐使用.需要数据库的ODBC驱动. 2 ...
- Java连接数据库 #06# SQL与代码分离(精化版本)
索引 DAO层依赖关系草图 应用示例 接Java连接数据库#05#,对代码进行改进. DAO层依赖关系草图 应用示例(只需3步!) 1.首先定义接口类: package org.sample.shop ...
- Java连接数据库 #05# SQL与代码分离
索引 读取html中的SQL语句 缺陷总结 在Java连接数据库 #04#里大概是这样放sql语句的: package org.sample.shop.db.queryrunner; import o ...
- java连接数据库(jdbc)调用配置文件
各种语言都有自己所支持的配置文件,后缀名“.properties”结尾的就是其中之一. 在java连接数据库时,采取读取配置文件的方式,来获取数据库连接. 新建jdbc.properties文件,内容 ...
- Java连接数据库 #04# Apache Commons DbUtils
索引 通过一个简单的调用看整体结构 Examples 修改JAVA连接数据库#03#中的代码 DbUtils并非是什么ORM框架,只是对原始的JDBC进行了一些封装,以便我们少写一些重复代码.就“用” ...
- JAVA连接数据库 #03# HikariCP
索引 为什么用数据库连接池? HikariCP快速入门 依赖 简单的草稿程序 设置连接池参数(只列举常用的) MySQL配置 修改Java连接数据库#02#中的代码 测试 为什么用数据库连接池? 为什 ...
- Java连接数据库 #02# JDBC经典套路
内容索引 LocalConnectionFactory.java LocalConnectionProxy.java ProfileDAO.java-2.0 ProfileDAOImpl.java-2 ...
随机推荐
- Linux修改服务器ip
Linux基础二(修改ip地址.修改网关.修改DNS服务器.重新启动网络配置) 网络的初始化 .ip地址的修改(临时生效) 使用ifconfig命令 ifconfig 网卡名 ip地址 netma ...
- Linux和windows下检查jsp后门文件的方法
Linux下: find . -name "*.jsp" | xargs egrep -liw "createNewFile| File\(| File |applica ...
- 解决方案:WindowsError: [Error 2]
使用Python的rename()函数重命名文件时出现问题,提示 WindowsError: [Error 2] 错误,最初代码如下: def renameFile(filename): filePr ...
- Item 30 用enum代替int常量类型枚举,string常量类型枚举
1.用枚举类型替代int枚举类型和string枚举类型 public class Show { // Int枚举类型 // public static final int APPLE_FUJI ...
- dp优化-四边形不等式(模板题:合并石子)
学习博客:https://blog.csdn.net/noiau/article/details/72514812 看了好久,这里整理一下证明 方程形式:dp(i,j)=min(dp(i,k)+dp( ...
- 【vijos】P1448 校门外的树
[题意]两种操作,[L,R]种新的树(不覆盖原来的),或查询[L,R]树的种类数.n<=50000. [算法]树状数组||线段树 [题解]这题可以用主席树实现……不过因为不覆盖原来的,所以有更简 ...
- 关于ssh三大框架整合的碎碎念
三大框架整合,无非就是一个导jar包,修改配置文件的过程.完了就没事了. 还是有很多细节性的问题 比如在spring中写applicationContext.xml文件时不提示: 解决方法如下: 如果 ...
- LINUX中断学习笔记【转】
转自:http://blog.chinaunix.net/uid-14825809-id-2381330.html 1.中断的注册与释放: 在 , 实现中断注册接口: int request_irq( ...
- python windows下安装celery调度任务时出错
由于celery 4.0不支持windows系统.所以用命令pip install Celery安装的celery是最新版4.0的不能在windows下运行. 在windows命令窗口运行: cele ...
- supervisor error: <class 'socket.error'>, [Errno 110]
supervisorctr status报错 error: <class 'socket.error'>, [Errno 110] Connection timed out: file: ...