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. SpringApplication.run

    SpringApplication.run一共做了两件事,分别是 创建SpringApplication对象 利用创建好的SpringApplication对象,调用run方法 1.创建SpringA ...

  2. 浅聊ARP

    今天借用思科公司的Cisco Packet Tracer Student这款软件浅聊ARP 什么是ARP? ARP即地址解析协议(Address Resolution Protocol),是根据Ip地 ...

  3. dedecms万能SQL标签使用方法大全

    注意:dede_archives这是系统默认的数据库表,如果你修改过表前缀dede_,请自行更改表名.在以下示例的标签中,有一部分只写出了SQL语句,具体的完整标签写法请参考:织梦SQL标签调用方法. ...

  4. trie浅谈

    关于trie ​ 其实字典树和以上两种算法有很大不同,但是hash由于其优秀的应用,导致有些字符串查找用hash也是可行的. ​ 字典树中支持添加,查找,区间查询(可持久化字典树),而且在异或操作上有 ...

  5. 2019牛客多校 Round7

    Solved:5 Rank:296 E Find the median (线段树) 题意:最开始一个空的数组 4e5次操作 每次把Li,Ri中的每个数插入进来 问当前的中位数 题解:把这n个区间离散化 ...

  6. Codeforces Round #635 C. Linova and Kingdom

    传送门:C. Linova and Kingdom 题意:给你一棵树,要求对k个结点涂色,然后统计每个未涂色结点到根结点的路径上未涂色结点的和,求和最大能为多少 题解:对着样例画几遍,然后贪心发现,最 ...

  7. .net中swagger忽略某些字段

    需要忽略的字段上用特性 [System.Text.Json.Serialization.JsonIgnore] 例如:

  8. 或许你知道Python的shell,那jshell呢?

    Java 10以后,java官方推出了类似python的shell操作的jshell,你的指令可以及时反馈,对于新手学习而言非常有用.如果你和我一样刚学Java,建议你使用高版本,和我一起开始使用js ...

  9. 在QT C++中调用 Python并将软件打包发布(裸机可运行)

    为了提高工作效率,需要一个可以自动生成多份相关联的word文档免去繁琐复制粘贴工作的软件.最后选定使用QT C++做界面和主要逻辑程序设计,对word的操作使用python写好对应的函数,然后在QT中 ...

  10. leetcode11 盛水容器 贪心

    这道题,总感觉做过... 先理解题意,何为容器 容器 要求水面高度相同 于是体积就是长方形,高度有两块较高板的低板决定,宽度由两块板间距离决定. 考虑当前最优解,就贪心 从两边开始向内,若能使得体积变 ...