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数据库 各个对象的理解的更多相关文章

  1. jdbc连接oracle数据库

    /*** 通过改变配置文件来连接不同数据库*/package com.xykj.jdbc; import static org.junit.Assert.*; import java.io.Input ...

  2. JAVA通过JDBC连接Oracle数据库详解【转载】

    JAVA通过JDBC连接Oracle数据库详解 (2011-03-15 00:10:03) 转载▼http://blog.sina.com.cn/s/blog_61da86dd0100q27w.htm ...

  3. JDBC连接Oracle数据库的问题

    场景:最近做一个java web项目,使用jdbc连接Oracle数据库,遇到了两个问题. 问题1:jdbc连接不上Ubuntu Oracle服务器? 后来发现这个问题的原因是由于连接字符串写错了,修 ...

  4. jdbc连接oracle数据库问题

    下面是JDBC连接oracle数据库流程: String dbURL = "jdbc:oracle:thin:@url:1521:service_name"; String use ...

  5. JDBC 连接Oracle 数据库,JDBC 连接Mysql 数据库

    首先是JDBC 连接Oracle  数据库 package com.util; import com.pojo.UserInfo; import java.sql.*; public class DB ...

  6. jdbc连接oracle数据库字符串

    jdbc连接oracle数据库有两种方式: 连接数据库SID 连接数据库service_name 当连接SID时,字符串如下: url::orcl1" password="xxxx ...

  7. 简单的JDBC连接oracle数据库例子

    java连接Oracle数据库 JDBC(Java Data Base Connectivity,java数据库连接),那么我们该如何用java进行数据库的连接呢. import java.sql.C ...

  8. JDBC连接Oracle数据库时出现的ORA-12505错误及解决办法

    转载至http://www.blogjava.net/itspy/archive/2007/12/20/169072.html Oracle 问题描述:今天使用jdbc连接oracle 10.2.0. ...

  9. 利用jdbc连接oracle数据库

    JDBC是Sun公司制定的一个可以用Java语言连接数据库的技术. 一.JDBC基础知识 JDBC(Java Data Base Connectivity,java 数据库连接)是一种用于执行SQL语 ...

随机推荐

  1. $().arr使用

    $("#handmoney").attr("readonly","readonly"); 只读 $("img").att ...

  2. linux常用命令(shell脚本常用命令)(grep、cut、sort、uniq、seq、tr、basename、dirname)

    本章命令: 1 2 3 4 5 6 grep cut sort uniq seq tr 1.grep 作用:过滤文本内容 选项 描述 -E :--extended--regexp 模式是扩展正则表达式 ...

  3. CCF-I'm stuck!(BFS)

    I'm stuck!   问题描述 给定一个R行C列的地图,地图的每一个方格可能是'#', '+', '-', '|', '.', 'S', 'T'七个字符中的一个,分别表示如下意思: '#': 任何 ...

  4. D - D (畅通工程再续)

    相信大家都听说一个"百岛湖"的地方吧,百岛湖的居民生活在不同的小岛中,当他们想去其他的小岛时都要通过划小船来实现.现在政府决定大力发展百岛湖,发展首先要解决的问题当然是交通问题,政 ...

  5. HDU-6881 Tree Cutting (HDU多校D10T5 点分治)

    HDU-6881 Tree Cutting 题意 \(n\) 个点的一棵树,要求删除尽量少的点,使得删点之后还是一棵树,并且直径不超过 \(k\),求删除点的数量 分析 补题之前的一些错误想法: 尝试 ...

  6. Codeforces Round #680 (Div. 2, based on Moscow Team Olympiad)【ABCD】

    比赛链接:https://codeforces.com/contest/1445 A. Array Rearrangment 题意 给定两个大小均为 \(n\) 的升序数组 \(a\) 和 \(b\) ...

  7. 2019 China Collegiate Programming Contest Qinhuangdao Onsite F. Forest Program(DFS计算图中所有环的长度)

    题目链接:https://codeforces.com/gym/102361/problem/F 题意 有 \(n\) 个点和 \(m\) 条边,每条边属于 \(0\) 或 \(1\) 个环,问去掉一 ...

  8. Educational Codeforces Round 20

    Educational Codeforces Round 20  A. Maximal Binary Matrix 直接从上到下从左到右填,注意只剩一个要填的位置的情况 view code //#pr ...

  9. Codeforces #Round 632 div2 A~C

                                       A. Little Artem   Young boy Artem tries to paint a picture, and h ...

  10. java实现定时任务解决方案

    在线corn表达式 1. 总结常见的实现定时任务的几种方法 thread实现 [原理:通过创建一个线程,让他在while循环里面一直运行,用sleep() 方法让其休眠从而达到定时任务的效果.] Ti ...