excel+怎么连接oracle(oracle如何连接oracle数据源)

Exce表格网 2023-02-25 21:55 编辑:admin 219阅读

1. oracle如何连接oracle数据源

PLSQL配置ORACLE连接的方法如下:

一、打开plsql的安装目录。

二、点开安装目录,找到客户端的安装目录instantclient。

三、点开目录network/admin,找到文件tnsnames.ora。

四、用文本编辑器打开tnsnames.ora,可以看到里面配置了很多数据库连接。

五、在底部新增一条连接记录,保存。

六、打开plsql,找到配置的别名,输入用户名密码,点击登录。

七、进入plsql操作界面。

八、新建一个sql command,写一条查询语句,查询成功。这样就可以配置新的连接了。

2. oracle 连接

1、嵌套循环链接(USE_NL)

主要消耗的相关资源:CPU,磁盘I/O

特点:在网上看到很多关于这方面的帖子,说小表作为驱动表,其实这种说话不完全正确,其实带条件的大表返回较少行的结果集也可以作为驱动表(外部表)。此表连接在当有高选择性索引或进行限制性搜索时候效率较高,可以快速返回第一次的搜索结果。

缺点:当索引丢失或查询条件限制不够时,效率很低。

2、排序合并连接(USE_MERGE)

主要消耗的相关资源:内存,临时表空间

特点:在排序合并连接中,ORACLE分别将第一个源表、第二个源表按他们各自要连接的列排序,然后将两个已经排序的源表合并。由于没有索引,排序合并连接在合并两表钱将强制对他们进行排序,两表都需要进行全表扫描,所以表名在FROM自居中出现的次序并不重要。当缺乏索引或搜索条件模糊时,该类型的连接比嵌套循环连接更加有效。

缺点:所有表都需要排序,它为最优化的吞吐量而设计,并且在结果没有全部找到之前不返回数据。

3、散列连接(USE_HASH)

主要消耗的相关资源:内存,临时表空间

特点:在散列连接中,ORACLE访问第一张表(通常是连接结果中较小的表),并且在内存中建立一张基于连接键的散列表,然后他扫描另外一张表(较大的表),并根据散列表检测是否有匹配的记录。当缺乏索引或搜索条件模糊时,该类型的连接比嵌套循环连接更加有效。通常比排序合并连接更快。

缺点:为建立散列表,需要大量的内存,第一次结果返回慢,如果在磁盘上操作,速度将更慢。

3. oracle数据库连接方法

在你的电脑上安装oracle客户端,然后在你安装的oracle客户端目录下查找tnsnames.ora文件,找到以后加上:;YOUR_ORACLE =; (DESCRIPTION =; (ADDRESS_LIST =; (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.200)(PORT = 1521)); ); (CONNECT_DATA =; (SERVICE_NAME = TEST); ); );如果你的数据库是SID为TEST,请把(SERVICE_NAME = TEST)改成(SID = TEST);如果用SQLPLUS连接,请写成sqlplus tzm/777@your_oracle;

如果用TOAD或者其他工具连接数据库:

4. oracle数据库怎么链接

首先选择connection type 为basic。数据库主机名一般是localhost(本地使用)。端口号和服务名我们可以自行查找:打开Oracle根目录,搜索tnsnames.ora文件,一般位置就在 …\product\11.2.0\dbhome_1\NETWORK\ADMIN下面,打开它可以看到我们需要的参数

5. 连接oracle数据库的语句

oracle数据库喜欢搞特殊,二进制字段数据不能直接插入,需先再该字段插入oracle函数返回的的初始数据,然后在查询更新该字段。下面以Blob字段类型为例:

1.插入初始数据

Class.forName("oracle.jdbc.driver.OracleDriver");

Connection cn= DriverManager.getConnection("jdbc:oracle:thin:@192.168.0.5:1521:orcl", "qywsbspt", "qywsbspt123999");

cn.setAutoCommit(false);

PreparedStatement pst = cn.prepareStatement("insert into t_uploadfile (file_id,file_content) values (?,EMPTY_BLOB())");

pst.setObject(1,8888);

pst.excuteUpdate();

2.查询更新该字段

pst = cn.prepareStatement("select file_content from t_uploadfile for updatewhere file_id = ? ");

pst.setObject(1,8888);

ResultSet rs = pst.excuteQuery();

BLOB blob = null ; //不是java.sql.Blob,而是oralce.sql.BLOB

if(rs.next())

blob = (BLOB)rs.getBlob(1); //获取该字段

OutputStream os =blob.getBinaryOutputStream(); //打开操作该字段的流

InputStream is = ...... //获取要插入的二进制文件的输入流

int buffer = -1;

while((buffer = is.read())!=-1){

os.write(buffer);

}

is.close();

os.close();

cn.commit();

rs.close();

pst.close();

cn.close();

顶一下
(0)
0%
踩一下
(0)
0%
相关评论
我要评论
点击我更换图片