Oracle Database Links实现方法解析 (oracle是什么)

技术教程 2025-05-02 07:35:05 浏览

什么是Database Links呢? 首先我们阐述下它的作用:使用户可以通过一个数据库访问到另外一个远程数据库。 那么Database Link是存储着远程数据库的连接信息。

Database

如下图所示:

用户Scott可以在本地数据库上查询远程数据库的emp表,我们可以在我们的本地数据库上建立一个别名(Synonym) emp,然后我们就可以直接通过select * from emp来查询远程数据库上的emp表,而无需通过select * from[emailprotected]的方式来查询。

这个远程的数据库可以是任何Oracle支持的远程数据库:Oracle ,DB2, sql Server, Taradata, MySQL…等等。 后面我还会介绍相关如何连接到非Oracle产品的数据库。

好了,知道了Database Link是什么,干什么用,Database Link的本质等,接下来我们介绍Database Link有哪几种连接方式的Link:

Link类型

说明

Connected user link

看这个类型的名称就可以判断出,用的是当前连接的用户的帐户及其密码来访问远程数据库的。所以这个类型就要求需要在远程数据库上有一个和本地帐户一样的username和password.

Fixed user link

这个类型是说使用指定的帐户和密码来访问远程数据库。所以只需指定的帐户能够有权限访问远程数据库就可以。

Current user link

需要用户连接到本地数据库的时候是全局用户的身份连接的。这样这个全局用户就可以使用指定帐户的上下文,而无需存储密码信息到link中。

上面是用来告诉Database Link,我们用用什么身份连接。

Database Link有以下类型:

类型

说明

来类型的Database Lin只能由这个Database Link的Owner才能使用它。

在这个数据库里的所有用户均可使用该Database Link

网络中的数据库中的用户均可使用该database link. 因为当Oracle 使用目录 服务器 的时候,它会在该目录下的所有数据库里都创建这个 Global cellspacing="0" cellpadding="0">

语句

说明

访问方式类型

连接类型

Create>

创建一个database link ,通过使用网络服务名称创建。其中Database Link的名称为dbLinkName. 网络服务的名称为NSName.

Connected user link

Create public>

创建一个database link ,通过使用网络服务名称创建。其中Database Link的名称为dbLinkName. 网络服务的名称为NSName.

Current user link

Create>

创建一个database link ,通过使用网络服务名称创建。其中Database Link的名称为dbLinkName. 网络服务的名称为NSName. 通过用户帐户username及其密码password来访问远程数据库。

Fixed user link

上面的地NSName的创建方式是需要在Oracle_home/Network/admin/tnsnames.ora里面配置。超出了本文的范围,我暂不做介绍。

如果不清楚如何配置NSName,那么我们可以按照以下方式写:

Create cellspacing="0" cellpadding="2">

Create cellspacing="0" cellpadding="2">

Select * from remoteTableName@dblinkName; 

其中remoteTableName是要访问的远程数据库里的表的名称,dblinkName既是先前我们创建的数据库连接。 这样每次访问表,写起来都有点麻烦;而且对于普通用户,这样的接口可能我们并不提供,换句话说,我们可能只让用户知道这里有什么表或者视图就可以了。这个时候我们可以使用别名(synonym)来简化/隐藏接口,语法如下

Links实现方法解析
CREATE [PUBLIC] synonym_name

FOR [schema.]object_name[@database_link_name];

Synonym支持一下的对象:

◆Materialized views

◆Sequences

◆Procedures

◆Functions

这里不做过多的讲解,我们为先前我们创造的database link来创建一个synonym,代码如下:

Create public tableName for remoteTableName@dblinkName; 

创建完成后,我们就可以这样访问远程数据库里的表:

Select * from tableName; 

上述语句等价于

Select * from remoteTableName@dblinkName; 

【编辑推荐


水解法对多糖结构分析的技术达到了什么水平

(1)葡萄糖不能水解成更简单的糖,所以为单糖;麦芽糖能水解,每个二糖分子水解后产生2个单糖分子,所以为二糖;淀粉能被水解,一个淀粉分子水解后产生多个单糖分子,所以为多糖.故答案为:葡萄糖,麦芽糖,淀粉.(2)180克葡萄糖在人体中氧化时,约能放出的能量为:180克×17.2kJ/克=3096kJ.设:生成的二氧化碳的质量为XC6H12O6+6O2酶6CO2+6H2O180 克 X=180克XX=264克答:180克葡萄糖在人体中氧化时约能放出能量3096kJ;180克葡萄糖在人体中氧化时,生成的二氧化碳的质量为264克.

PL/SQL里 execute immediate的用法 谁给解释下

在ORACLE的PL/SQL里:EXECUTE IMMEDIATE 代替了以前Oracle8i中DBMS_SQL package包.它解析并马上执行动态的SQL语句或非运行时创建的PL/SQL块.动态创建和执行SQL语句性能超前,EXECUTE IMMEDIATE的目标在于减小企业费用并获得较高的性能,较之以前它相当容易编码.尽管DBMS_SQL仍然可用,但是推荐使用EXECUTE IMMEDIATE,因为它获的收益在包之上。 -- 使用技巧1. EXECUTE IMMEDIATE将不会提交一个DML事务执行,应该显式提交如果通过EXECUTE IMMEDIATE处理DML命令,那么在完成以前需要显式提交或者作为EXECUTE IMMEDIATE自己的一部分.如果通过EXECUTE IMMEDIATE处理DDL命令,它提交所有以前改变的数据2. 不支持返回多行的查询,这种交互将用临时表来存储记录(参照例子如下)或者用REF cursors.3. 当执行SQL语句时,不要用分号,当执行PL/SQL块时,在其尾部用分号.4. 在Oracle手册中,未详细覆盖这些功能。 下面的例子展示了所有用到Execute immediate的可能方面.希望能给你带来方便.5. 对于Forms开发者,当在PL/SQL 8.0.6.3.版本中,Forms 6i不能使用此功能 IMMEDIATE -- 用法例子1. 在PL/SQL运行DDL语句beginexecute immediate set role all;end;2. 给动态语句传值(USING 子句)declarel_depnam varchar2(20) := testing;l_loc varchar2(10) := Dubai;beginexecute immediate insert into dept values (:1, :2, :3)using 50, l_depnam, l_loc;commit;end;3. 从动态语句检索值(INTO子句)declarel_cnt varchar2(20);beginexecute immediate select count(1) from empinto l_cnt;dbms__line(l_cnt);end;4. 动态调用例程.例程中用到的绑定变量参数必须指定参数类型.黓认为IN类型,其它类型必须显式指定declarel_routinvarchar2(100) := _rowcnt;l_tblnamvarchar2(20) := emp;l_cnt number;l_statusvarchar2(200);beginexecute immediate begin || l_routin || (:2, :3, :4); end;using in l_tblnam, out l_cnt, in out l_status; if l_status != OK then dbms__line(error);end if;end;5. 将返回值传递到PL/SQL记录类型;同样也可用%rowtype变量declaretype empdtlrec is record (empno number(4), ename varchar2(20), deptno number(2));empdtl empdtlrec;beginexecute immediate select empno, ename, deptno || from emp where empno = 7934into empdtl;end;6. 传递并检索值子句用在USING子句前declarel_dept pls_integer := 20;l_namvarchar2(20);l_locvarchar2(20);beginexecute immediate select dname, loc from dept where deptno = :1into l_nam, l_locusing l_dept ;end;7. 多行查询选项.对此选项用insert语句填充临时表,用临时表进行进一步的处理,也可以用REF cursors纠正此缺憾_salpls_integer := 2000;beginexecute immediate insert into temp(empno, ename) || select empno, ename from emp || where sal > :1using l_sal;commit;end;对于处理动态语句,EXECUTE IMMEDIATE 比以前可能用到的更容易并且更高效.当意图执行动态语句时,适当地处理异常更加重要.应该关注于捕获所有可能的异常.

3x的平方加4xy减y平方 因式分解

将3x²+4xy-y²

看作是关于x的二次三项式

则它对应的一元二次方程为:3x²+4xy-y²

Δ=﹙4y﹚²-4×3×﹙﹣y²﹚=28y²≥0

∴x=﹙﹣4y±2√7· y﹚/6即﹙﹣2y±√7 y﹚/3

∴原式可分解因式为:3[x-﹙﹣2y/3+√7y/3﹚][x-﹙﹣2y/3-√7y/3﹚]

即3﹙x+2y/3-√7y/3﹚﹙x+2y/3+√7y/3﹚

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐