1. Oracle中 多表连接到底有哪几种方式
oracle中多表连接有很多种方式:
1、表与表连接有三种方式Nested loop, Hash join, Sort merge join。
2、Nested Loop就是循环嵌套的连接方法,对于被连接子集都是比较小的话,嵌套循环就是比较好的选择。在嵌套中,内表被外表驱动,外表做一次循环,内表针对外表的每一行做循环。
3、这种表的返回结果集不能太大,否则就效率实在太低的,而且还要用在表都有索引的情况下才行的。
4、Sort Merge Join 用在数据没有索引,并且数据必须是都排序号的情况。
5、总之,两表之间相连,会根据表之间的不同情况选择不同的连接方式,连接其实就是做表之间每行数据的遍历,连之前都要做好准备,有么用索引,要么用已排序号的表,要么就用hash算法,不存在什么都不准备的纯遍历循环。
6、三种连接使用前提,当表都排序号的话用Sort Merge Join连接,当两表都差不多大而且都还有索引就用Nested Loop的嵌套连接,当没有索引也没排序,而且数据量大的情况下就用这个hash算法进行相连。
2. 客户端连接ORACLE的几种方法
装个跟服务端上相同版本的oracle客户端,再装个pl/sql配置一下就能连上了:
找到你oracle客户端安装目录中的tnsnames.ora文件,修改
zbds_251=
(description=
(address_list=
(address=(protocol=tcp)(host=140.28.19.251)(port=1521))
)
(connect_data=
(service_name=zbds)
)
)
“zbds”是你的oracle数据库实例名,140.28.19.251是你的远程服务器的ip,“zbds_251”随便起,是给pl/sql看的。