JDBC学过但又属于很容易忘记的那种,每次要用到,都要看下连接模式。每次找又很费时间,总之好麻烦呀呀呀,所以写篇博客,总结下原理和常用接口,要是又忘了可以直接来博客上看,嘿嘿。

一、什么是JDBC

1、JDBC全称是 Java DataBase Connectivity,可以为多种关系型数据库DBMS提供统一的访问方式,主要目的是用Java来操作数据库。

2、JDBC API主要负责三个功能:(1)与数据库建立连接(2)发送SQL语句给数据库(3)数据库将结果返回

具体过程大致是这样子的:

3、实现方法:(1)DriverManager:管理jdbc驱动(2)Connection 连接数据库(3)Statement(PreparedStatement)增删改查 CallableStatement 调用数据库的存储过程和存储函数 (4)ResultSet 结果集

4、实现步骤:(1)导入驱动,加载具体驱动类(2)与数据库建立连接(3)执行SQL语句(4)返回结果

5、常见数据库 oracle,mysql,SQLServer的加载驱动

oracle---具体驱动类:oracle.jdbc.OracleDriver     连接字符串:jdbc:oracle:thin:@localhost(ip地址):1521:ORCL

mysql---具体驱动类:com.mysql.jdbc.Driver    连接字符串:jdbc:mysql://localhost(ip地址):3306/数据库实名

SQLServer---具体驱动类:com.microsoft.sqlserver.jdbc.SQLServerDriver     连接字符串:jdbc.microsoft.sqlserver:localhost(ip地址):1433;数据库实名

6、举个实例(以mysql数据库为例)实现对数据库增删改 查

建一个JDBCDemo

public class JDBCDemo {
private String driver="com.mysql.jdbc.Driver";
private String url="jdbc:mysql://localhost:3306/test";
private String username="root";
private String password="root";
Connection conn=null;
Statement statement=null;
ResultSet set=null;
public void updateSql(){
try{
//加载驱动类
Class.forName(driver);
//与数据库建立连接
conn= DriverManager.getConnection(url,username,password);
//发送SQL语句
statement=conn.createStatement();
//插入数据
String sql="insert into user(username,password) values('114','1234')";
//修改数据
//String sql="update user set password='1232' where id=2"
//删除数据
//String sql= "delete from user where id=2";
//sql语句结果,一般进行 增删改 的SQL语句用excuteUpdate
int count=statement.executeUpdate(sql);
if(count>0){
System.out.println("操作成功");
}else{
System.out.println("操作失败");
}
}catch(ClassNotFoundException e){
e.printStackTrace();
}catch (SQLException e){
e.printStackTrace();
}catch (Exception e){
e.printStackTrace();
}finally {
try {
if (statement == null) {//用判断来防止statement空异常
statement.close();
}
if (conn == null) {
conn.close();
}
}catch (SQLException e){
e.printStackTrace();
} }
}
public void querySql(){
try{
//加载驱动类
Class.forName(driver);
//与数据库建立连接
conn= DriverManager.getConnection(url,username,password);
//发送SQL语句
statement=conn.createStatement();
String sql="select * from user where username='111' and password='1234' ";
//返回结果集
set=statement.executeQuery(sql);
while(set.next()){
//用两种方式获取值,一种是根据列名,一种是所在的列数
String name=set.getString("username");
String pass=set.getString("password");
//String name=set.getString(2);
// String pass=set.getString(3);
System.out.println(name+","+pass);
}
}catch(ClassNotFoundException e){
e.printStackTrace();
}catch (SQLException e){
e.printStackTrace();
}catch (Exception e){
e.printStackTrace();
}finally {
try {
if (statement == null) {//用判断来防止statement空异常
statement.close();
}
if (conn == null) {
conn.close();
}
}catch (SQLException e){
e.printStackTrace();
}
}
}

上述代码主要使用Statement方式发送SQL,还有preparedStatement方式。他们之间有相同点,但是又不是一样,下面就来比较下Statement和PreparedStatement

二、Statement与PreparedStatement的比较

Statement:(1)产生方式:Connection.createStatement()(2)增删改 executeUpdate()(3)查询 executeQuery()(4)一般将SQL语句放在executeUpdate()中

PreparedStatement:(1)产生方式:Connection.prepareStatement()(2)增删改 executeUpdate()(3)查询 executeQuery()(4)一系列SetXXX方法(5)将SQL放在Connection.PrepareStatement(SQL)(6)需要预编译

查看PreparedStatement的源码 ,可知PreparedStatement继承Statement,Statement里有的方法PreparedStatement都有,但是PreparedStatement还有很多SetXXX方法

用代码直观的体现两者的区别:

除了这部分之外,其他和上述代码一样,多了一步预编译。

三、PreparedStatement较Statement的优势

(1)编码更加简洁灵活:在PreparedStatement中SQL语句后的查询条件,插入的值可以用占位符(?)来表示,不用像Statement一样写具体的值,只需要调用PreparedStatement中的SetXXX方法赋值即可。

(2)提高性能:如果要执行一条SQL语句100回,Statement需要connection,createStatement(sql)语句编译SQL100次,PreparedStatemnet只需要编译SQL语句一回(即connection.PreparedStatement(sql)),重复执行100次preparedStatement.executeQuery();减少编译SQL次数,提高性能。

(3)安全性高,可以有效防止SQL注入的风险:Statement存在SQL注入的风险,PreparedStatement可以防止SQL注入的风险。

最新文章

  1. maven建立本地仓库
  2. Eclipse里项目名有红叉,但是底下的每一个文件都没有红叉
  3. 开发环境中biztalk项目设置注意事项(转)
  4. C# 反射操作方法
  5. apk的重签名
  6. 我的Spring学习记录(三)
  7. idea远程打断点
  8. Koa源码分析(一) -- generator
  9. Apache Flink 简单安装
  10. mongodb数据库中插入数据
  11. MyCAT 源码解析 —— 分片结果合并(使用unsaferow)
  12. xmlhttp.readyState==4 && xmlhttp.status==200的探究
  13. (转)windows平台时间函数性能比较QueryPerformanceCounter,GetTickCount,ftime,time,GetLocalTime,GetSystemTimeAsFileTime
  14. Codeforces Round #533 (Div. 2) Solution
  15. 20181009-7 选题 Scrum立会报告+燃尽图 06
  16. 安装TestNG在eclipse中的插件
  17. mxonline实战9,我要学习功能块,机构详情展示,收藏功能
  18. Android开发之Google Map
  19. cx_Oracle连接数据库总结
  20. 1002. 查找常用字符 leecode

热门文章

  1. linux rm 删除命令
  2. .net core中Grpc使用报错:The remote certificate is invalid according to the validation procedure.
  3. C#中CancellationToken和CancellationTokenSource用法
  4. Ubuntu18.04升级内核后修改grub文件启动顺序
  5. centos 操作系统优化
  6. 使用altium designer 21极坐标绘制异形焊盘 比如焊接螺母的 环绕焊盘
  7. 钓鱼攻击之远程加载恶意Word模版文件上线CS
  8. 【PTA】6-1 计算两个复数之积 (10 分)
  9. 面试必问之 CopyOnWriteArrayList,你了解多少?
  10. MCU软件最佳实践——独立按键