JDBC 连接Oracle数据库 各个对象的理解
JDBC:
1. **代码实现:(连接oracle数据库)
1.导入驱动jar包
2.注册驱动
Class.forName("oracle.jdbc.driver.OracleDriver");
3.获取数据库连接对象
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:端口号/数据库名","user","password");
4.定义sql语句
String sql = "update XE set name='ttt' where id = 1";
5.获取执行sql的对象 Statement
Statement stmt = conn.createStatement();
6.执行sql
int i =stmt.executeUpdate(sql);
7.处理结果
System.out.println(i);
8.释放资源
stmt.close();
conn.close();
2.详解各个对象
1.DriverManager:驱动管理对象
*功能:
1.注册驱动:告诉程序去使用哪一个数据库驱动jar包
(DriverManager类中有一个注册驱动的静态方法 registerDriver(Driver driver,DriverAction da))通过查看源码可知oracle.jdbc.driver.OracleDriver类中有一段静态代码块,里面有注册驱动的代码。
2.获取数据库连接:
*方法:static Connection getConnection(String url,String user,String password)
*参数:
url:指定链接的路径 ip 端口 数据库名
user:用户名
password:密码
2.Connection:数据库连接对象
1.功能:
1.获取执行sql的对象
*Statement createStatement()
*PreparedStatement prepareStatement(String sql)
2.管理事务:
* 开启事务 setAutoCommit(boolean autoCommit)设置为false,既开启事务。
* 提交事务 commit()
* 回滚事务 rollback()
3.Statement:执行sql对象 (处理静态的sql语句)
1.boolean execute(String sql): 可以执行任何sql 了解
2.int executeUpdate(String sql):执行DML语句(insert、update、delete),DDL(create、alter、drop)语句
返回值:表示影响的行数。返回值>0执行成功
3.ResultSet executeQuery(String sql):执行DQL(select)语句
返回的是结果集对象
4.PreparedStatement:执行sql对象 (处理动态的sql语句,也就是预处理的sql语句)
1.SQL注入问题:在拼接sql时,有一些sql的特殊关键字参与字符串的拼接。会造成安全性问题
1.输入用户随便,输入密码:a' or 'a'='a
2.sql : select * from user where username = 'dsfudgu' and password = 'a' or 'a'='a'
2.解决sql注入问题 :使用PreparedStatement对象解决问题
3.预编译的SQL:参数使用?作为占位符
4.步骤:
1.导入驱动jar包
2.注册驱动
Class.forName("oracle.jdbc.driver.OracleDriver");
3.获取数据库连接对象 Connection
4.定义sql语句
* 注意:sql 的参数使用?作为占位符。如 select * from user where username = ?and password = ?;
5.获取执行sql的对象 PreparedStatement
Connection.PreparedStatement(String sql);
6.给?赋值:
* 方法:setxxx(参数1,参数2 )
*参数1:?的位置编号从1开始
*参数2:?的值
7.执行sql
int i =stmt.executeUpdate();
8.处理结果
9.释放资源
ps.close();
conn.close();
5.ResultSet:结果集对象,封装查询结果的
* boolean next(): 游标向下移动一行 判断当前行时候是最后一行,如果是,则返回false,否则返回true
* getxxx(参数): 获取数据
*xxx: 代表数据类型
*参数
1.Int: 代表列的编号,从1开始。 如getString(1) 获取第一列的值
2. String:列的名称
*注意:
*使用步骤:
1.游标向下移动一行
2.判断时候有数据
3.获取数据
JDBC 连接Oracle数据库 各个对象的理解的更多相关文章
- jdbc连接oracle数据库
/*** 通过改变配置文件来连接不同数据库*/package com.xykj.jdbc; import static org.junit.Assert.*; import java.io.Input ...
- JAVA通过JDBC连接Oracle数据库详解【转载】
JAVA通过JDBC连接Oracle数据库详解 (2011-03-15 00:10:03) 转载▼http://blog.sina.com.cn/s/blog_61da86dd0100q27w.htm ...
- JDBC连接Oracle数据库的问题
场景:最近做一个java web项目,使用jdbc连接Oracle数据库,遇到了两个问题. 问题1:jdbc连接不上Ubuntu Oracle服务器? 后来发现这个问题的原因是由于连接字符串写错了,修 ...
- jdbc连接oracle数据库问题
下面是JDBC连接oracle数据库流程: String dbURL = "jdbc:oracle:thin:@url:1521:service_name"; String use ...
- JDBC 连接Oracle 数据库,JDBC 连接Mysql 数据库
首先是JDBC 连接Oracle 数据库 package com.util; import com.pojo.UserInfo; import java.sql.*; public class DB ...
- jdbc连接oracle数据库字符串
jdbc连接oracle数据库有两种方式: 连接数据库SID 连接数据库service_name 当连接SID时,字符串如下: url::orcl1" password="xxxx ...
- 简单的JDBC连接oracle数据库例子
java连接Oracle数据库 JDBC(Java Data Base Connectivity,java数据库连接),那么我们该如何用java进行数据库的连接呢. import java.sql.C ...
- JDBC连接Oracle数据库时出现的ORA-12505错误及解决办法
转载至http://www.blogjava.net/itspy/archive/2007/12/20/169072.html Oracle 问题描述:今天使用jdbc连接oracle 10.2.0. ...
- 利用jdbc连接oracle数据库
JDBC是Sun公司制定的一个可以用Java语言连接数据库的技术. 一.JDBC基础知识 JDBC(Java Data Base Connectivity,java 数据库连接)是一种用于执行SQL语 ...
随机推荐
- OsgEarth开发笔记(三):Osg3.6.3+OsgEarth3.1+vs2019x64开发环境搭建(下)
前言 上一篇编译了proj6.2.0.gdal3.2.1,本篇继续. OsgEarth编译过程简介 OsgEarth的编译,是基于Osg和OsgEarth结合在一起的,先要编译Osg,然后 ...
- 2020 ICPC Universidad Nacional de Colombia Programming Contest
2020 ICPC Universidad Nacional de Colombia Programming Contest A. Approach 三分 显然答案可以三分,注意\(eps\)还有两条 ...
- gym101002K. Inversions (FFT)
题意:给定一个仅含有AB的字母串 如果i有一个B j有一个A 且j>i 会对F(j-i)产生贡献 求出所有发Fi 题解:好像是很裸的FFT B的分布可以看作一个多项式 同理A也可以 然后把B的位 ...
- 【LA 3487】Duopoly(图论--网络流最小割 经典题)
题意:C公司有一些资源,每种只有1个,有A.B两个公司分别对其中一些资源进行分组竞标,每组竞标对一些资源出一个总价.问C公司的最大收益. 解法:最小割.将A公司的竞标与源点相连,B公司的与汇点相连,边 ...
- UVA 10480 Sabotage (最大流) 最小割边
题目 题意: 编写一个程序,给定一个网络规范和破坏每个连接的成本,确定要切断哪个连接,以便将首都和最大的城市分离到尽可能低的成本. 分割-------------------------------- ...
- HDU 3605 Escape 最大流
题意: 如果这是2012年世界末日怎么办?我不知道该怎么做.但是现在科学家们已经发现,有些星球上的人可以生存,但有些人却不适合居住.现在科学家们需要你的帮助,就是确定所有人都能在这些行星上生活.输入多 ...
- 单源最短路问题 Dijkstra 算法(朴素+堆)
选择某一个点开始,每次去找这个点的最短边,然后再从这个开始不断迭代,更新距离. 代码: 朴素(vector存图) #include <iostream> #include <cstd ...
- C# 替换文件名的字符
https://www.cnblogs.com/lindexi/p/8970466.html
- 数理统计8:点估计的有效性、一致最小方差无偏估计(UMVUE)、零无偏估计法
在之前的学习中,主要基于充分统计量给出点估计,并且注重于点估计的无偏性与相合性.然而,仅有这两个性质是不足的,无偏性只能保证统计量的均值与待估参数一致,却无法控制统计量可能偏离待估参数的程度:相合性只 ...
- Zabbix 触发器配置多监控项阈值
配置内存自定义监控项 # 监控内存命令 [root@web01 ~]# free -m|awk '/^Mem/{print $NF/$2}' 0.664609 [root@web01 ~]# free ...