Jdbc笔记(第一部分:基础)

一、基本概述
jdbc全称(java DataBase Connectivity),即就是使用Java语言操作数据库中的数据(在这里需要注意的是大部分情况下操作数据库中的数据,即就是对数据库表中的记录进行相应的操作也就是通俗意义上的增,删,改,查;很少对数据库或者表进行相应操作也就是很少使用DDL语言)。
二、JDBC的基本原理
由于数据库不止一种,像我们熟知的MySql,Oracal,SqlServel,Access等等,早期SUN公司的天才们想编写一套可以连接天下所有数据库的API,但是当他们刚刚开始时就发现这是不可完成的任务,因为各个厂商的数据库服务器差异太大了。后来SUN开始与数据库厂商们讨论,最终得出的结论是,由SUN提供一套访问数据库的规范(就是一组接口),并提供连接数据库的协议标准,然后各个数据库厂商会遵循SUN的规范提供一套访问自己公司的数据库服务器的API出现。SUN提供的规范命名为JDBC,而各个厂商提供的,遵循了JDBC规范的,可以访问自己数据库的API被称之为驱动!
JDBC是接口,而JDBC驱动才是接口的实现,没有驱动无法完成数据库连接!每个数据库厂商都有自己的驱动,用来连接自己公司的数据库。
当然还有第三方公司专门为某一数据库提供驱动,这样的驱动往往不是开源免费的!
三,Jdbc的核心类
1.DriverManager:用来获取Connection对象
*DriverManager.getConenction(url,DataBaseName,DataBasePassword);
2.Connection:该类的对象可以获取Statement/PrepareStatement对象
*conn.getStatement();
*conn.getPrepareStatement(String sql);由于PrepareStatement对象与sql模板绑定,所以在创建该对象时需要传一个sql语句参数;
3.PrepareStatement:Statement是PreppareStament的父接口,这两种接口有些区别,但这两种类都有相同的两个方法
*int executeUpdate (String sql):执行更新操作,即执行insert、update、delete语句,其实这个方法也可以执行create table,alter table,以及drop table等语句,但我们很少会使用JDBC来执行这些语句;
*ResultSet executeQuery (String sql):执行查询操作,执行查询操作会返回ResultSet,即结果集
4. ResultSet:结果集,主要用在查询语句中,用来接收查询到的结果集。
ResultSet之获取列数据
可以通过next()方法使ResultSet的游标向下移动,当游标移动到你需要的行时,就需要来获取该行的数据了,ResultSet提供了一系列的获取列数据的方法:
String getString(int columnIndex):获取指定列的String类型数据;
int getInt(int columnIndex):获取指定列的int类型数据;
double getDouble(int columnIndex):获取指定列的double类型数据;
boolean getBoolean(int columnIndex):获取指定列的boolean类型数据;
Object getObject(int columnIndex):获取指定列的Object类型的数据。
5.Statement和PrepareStatement的区别:
两者的区别即就是前者容易发生SQL注入,而后者则可以在一定程度上避免这种情况的出现(当然防止SQL注入也可以通过其他方式.);它最大的优势即就是预处理,由于该接口的与语句sql模板绑定,当第一次执行由该接口实现类的对象执行某一sql语句时,将sql语句传给数据库后需要对sql模板进行语法校验,再进行编译,执行时只把参数传递过去即可。等到第二次再次执行相同的sql语句时,则不再对sql模板的语法进行校验,也不再进行编译,而是直接传递相应的参数执行即可。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一、概述: JDBC从物理结构上说就是Java语言访问数据库的一套接口集合。从本质上来说就是调用者(程序员)和实现者(数据库厂商)之间的协议。JDBC的实现由数据库厂商以驱动程序的形式提供。JDBC API 使得开发人员可以使用纯Java的方式来连接数据库,并进行操作。 ODBC:基于C语言的数据库访问接口。 JDBC也就是Java版的ODBC。 JDBC的特性:高度的一致性、简单性(常用的接口只有4、5个)。 1.在JDBC中包括了两个包:java.sql和javax.sql。 ① java.sql 基本功能。这个包中的类和接口主要针对基本的数据库编程服务,如生成连接、执行语句以及准备语句和运行批处理查询等。同时也有一些高级的处理,比如批处理更新、事务隔离和可滚动结果集等。 ② javax.sql 扩展功能。它主要为数据库方面的高级操作提供了接口和类。如为连接管理、分布式事务和旧有的连接提供了更好的抽象,它引入了容器管理的连接池、分布式事务和行集等。 注:除了标出的Class,其它均为接口。 API 说明 java.sql.Connection 与特定数据库的连接(会话)。能够通过getMetaData方法获得数据库提供的信息、所支持的SQL语法、存储过程和此连接的功能等信息。代表了数据库。 java.sql.Driver 每个驱动程序类必需实现的接口,同时,每个数据库驱动程序都应该提供一个实现Driver接口的类。 java.sql.DriverManager (Class) 管理一组JDBC驱动程序的基本服务。作为初始化的一部分,此接口会尝试加载在”jdbc.drivers”系统属性中引用的驱动程序。只是一个辅助类,是工具。 java.sql.Statement 用于执行静态SQL语句并返回其生成结果的对象。 java.sql.PreparedStatement 继承Statement接口,表示预编译的SQL语句的对象,SQL语句被预编译并且存储在PreparedStatement对象中。然后可以使用此对象高效地多次执行该语句。 java.sql.CallableStatement 用来访问数据库中的存储过程。它提供了一些方法来指定语句所使用的输入/输出参数。 java.sql.ResultSet 指的是查询返回的数据库结果集。 java.sql.ResultSetMetaData 可用于获取关于ResultSet对象中列的类型和属性信息的对象。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值