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语 ...
随机推荐
- OSPF特殊区域和LSA
OSPF路由计算优选次序: (1) 直连路由:本路由器发起的LSA 1.2: (2) 区域内路由:O: LSA 1.2: (3) 区域间路由:O IA: LSA 3: (4) 1类外部路由:O E1: ...
- java 石头剪子布游戏
源代码 StoneGame.java 1 import java.io.BufferedReader; 2 import java.io.IOException; 3 import java.io.I ...
- MongoDB:原来我如此简单
为什么要使用 MongoDB 张三大学毕业设计题目是<XXX博客论坛>,他在存储用户评论的时候遇到了一个问题:这些评论数据量非常大,但是价值不是很大,如果存储在 MySQL 数据库中就会浪 ...
- Hive 中日志的存放位置
目前hive启动无法成功,想查看下hive的日志定位问题,但发现hive的安装目录下并没有hive的日志,后来经过在网上谷歌发现: Hive中的日志分为两种 系统日志,记录了hive的运行情况,错误状 ...
- 小白的经典CNN复现(三):AlexNet
小白的经典CNN复现(三):AlexNet 锵锵--本系列的第三弹AlexNet终于是来啦(≧∀≦),到了这里,我们的CNN的结构就基本上和现在我们经常使用或者接触的一些基本结构差不多了,并且从这一个 ...
- Educational Codeforces Round 90 (Rated for Div. 2) C. Pluses and Minuses(差分)
题目链接:https://codeforces.com/contest/1373/problem/C 题意 给出一个只含有 $+$ 或 $-$ 的字符串 $s$,按如下伪代码进行操作: res = 0 ...
- 2017-2018 ACM-ICPC German Collegiate Programming Contest (GCPC 2017)(9/11)
$$2017-2018\ ACM-ICPC\ German\ Collegiate\ Programming\ Contest (GCPC 2017)$$ \(A.Drawing\ Borders\) ...
- hdu 1517 Multiplication Game
题意: 用整数p乘以2到9中的一个数字.斯坦总是从p = 1开始,做乘法,然后奥利乘以这个数,然后斯坦,以此类推.游戏开始前,他们画一个整数1 < n < 4294967295,谁先到达p ...
- 流媒体传输协议之 RTP (上篇)
本系列文章将整理各个流媒体传输协议,包括 RTP/RTCP,RTMP,希望通过深入梳理协议的设计细节,能够给流媒体领域的开发者带来一定的启发. 作者:逸殊 审核:泰一 介绍 RTP,即 real-ti ...
- Redis 持久化(Persistence)
作为内存数据库,Redis 依然提供了持久化机制,其主要目的有两个: 安全:保证进程崩溃后数据不会丢失 备份:方便数据迁移与快速恢复 Redis 同时提供两种持久化机制: RDB 快照:数据库在某个时 ...