java操作oracle和一些技巧

java连接oracle ,有两种方式:一种是odbc的方式,另外一种是jdbc方式

odbc方式:

Java代码 :
  1. package com.sp;   
  2.   
  3. import java.sql.Connection;   
  4. import java.sql.DriverManager;   
  5. import java.sql.ResultSet;   
  6. import java.sql.Statement;   
  7.   
  8. //演示  如何使用 jdbc_odbc桥连接方式   
  9. public class TestOracle {   
  10.   
  11.     public static void main(String[] args) {   
  12.         try {   
  13.   
  14.             // 1.加载驱动   
  15.             Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");   
  16.   
  17.             // 2.得到连接   
  18.             Connection ct = DriverManager.getConnection(   
  19.                     "jdbc.odbc:testConnectOracle""scott",    
  20.   
  21. "tiger");   
  22.   
  23.             // 从下面开始,和SQL Server一模一样   
  24.             Statement sm = ct.createStatement();   
  25.             ResultSet rs = sm.executeQuery("select * from emp");   
  26.             while (rs.next()) {   
  27.                 //用户名   
  28.                 System.out.println("用户名: "+rs.getString(2));   
  29.                 //默认是从1开始编号的   
  30.             }   
  31.         } catch (Exception e) {   
  32.             e.printStackTrace();   
  33.         }   
  34.     }   
  35. }  

在得到连接那里,要去配置数据源,点击控制面板-->系统和安全-->管理工具-->数据源(ODBC),

打开后点添加,如图:
可以看到,有个Oracle in OraDb10g_home1的驱动,它是Oracle安装完后自动加上去的。 选中

后,点完成,再填如下信息,如图:


这样配好后基本就可以了,但为了安全起见,建议大家测试一下,点击 Test Connection按钮,

测试通过后点ok,然后数据源就生成了,如图:


然后把数据源名称写进jdbc.odbc:???里。

这里要注意:jdbcodbc能不能远程连接呢?不能远程连接,也就是你这样写的话就意味着java程

序和oracle数据库应该是在同一台机器上,因为这里没有指定IP地址,肯定默认就是本地
。 如

果要远程连,就用jdbc,jdbc是可以远程连的。

用JDBC的方式连接Oracle

  1. package com.sp;   
  2.   
  3. import java.sql.Connection;   
  4. import java.sql.DriverManager;   
  5. import java.sql.ResultSet;   
  6. import java.sql.Statement;   
  7.   
  8. //使用 jdbc连接oracle   
  9. public class TestOracle2 {   
  10.   
  11.     public static void main(String[] args) {   
  12.         try {   
  13.   
  14.             // 1.加载驱动   
  15.             Class.forName("oracle.jdbc.driver.OracleDriver");   
  16.   
  17.             // 2.得到连接   
  18.             Connection ct = DriverManager.getConnection   
  19.   
  20. ("jdbc:oracle:thin:@127.0.0.1:1521:orcl""scott""tiger");   
  21.   
  22.             // 从下面开始,和SQL Server一模一样   
  23.             Statement sm = ct.createStatement();   
  24.             ResultSet rs = sm.executeQuery("select * from emp");   
  25.             while (rs.next()) {   
  26.                 //用户名   
  27.                 System.out.println("用户名: "+rs.getString(2));   
  28.                 //默认是从1开始编号的   
  29.             }   
  30.         } catch (Exception e) {   
  31.             e.printStackTrace();   
  32.         }   
  33.     }   
  34. }  

在oracle中操作数据 - 使用特定格式插入日期值
 使用 to_date函数
请大家思考: 如何插入列带有日期的表,并按照年-月-日的格式插入?
insert into emp values  (9998,  'xiaohong',  'MANAGER',  7782,  to_date('1988-12-

12', 'yyyy-mm-dd'),  78.9,  55.33,  10);

注意:
insert into emp values  (9998,  'xiaohong',  'MANAGER',  7782,  '12-12月-1988',

78.9,  55.33,  10);
这句语句是可以成功运行的



使用子查询插入数据
 介绍
当使用valus子句时,一次只能插入一行数据,当使用子查询插入数据时,一条inset语句可以插

入大量的数据。当处理行迁移或者装载外部表的数据到数据库时,可以使用子查询来插入数据。
把emp表中10号部门的数据导入到新表中
create table kkk(myId number(4), myName varchar2(50), myDept number(5));
insert into kkk (myId, myName, myDept)  select empno, ename, deptno from emp where

deptno = 10;

 介绍
使用update语句更新数据时,既可以使用表达式或者数值直接修改数据,也可以使用子查询修改

数据。
问题:希望员工SCOTT的岗位、工资、补助与SMITH员工一样。
update emp set(job, sal, comm)=(select job, sal, comm from emp where ename='SMITH')

where ename='SCOTT';


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yjsuge

你的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值