taradatainsertinto多行数据报错

taradatainsertinto多行数据报错,第1张

写法错误。

根据数据库报错情况分析,插入数据的标准写法是insertintos(col1,col2,col3.)valus(value1,value2,value3.),如果后面的数据项和表的字段数量可以对应上,则可以省略。

处理逻辑whenexception_codethen-这里的错误代码可以在standard包中找到。

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

这个远程的数据库可以是任何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有以下类型:

类型

说明

Private

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

Public

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

Global

网络中的数据库中的用户均可使用该database link. 因为当Oracle 使用目录服务器的时候,它会在该目录下的所有数据库里都创建这个 global database link,并且统一控制。因此所有在目录下的数据库里的用户均可使用。

好了,让我们看看应该如何创建一个Database Link:

语法:create [type] database link

语句

说明

访问方式类型

连接类型

Create database link dblinkName using ‘NSName’

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

Connected user link

Private

Create public database link dblinkName connect to CURRENT_USER using ‘NSName’

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

Current user link

public

Create database link dblinkName dblinkName connect to username identified by password using ‘NSName’

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

Fixed user link

private

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

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

Create database link dblinkName dblinkName connect to username identified by password using ‘NSNName=

(

Address_List=

(

(Adress=(protocol=TCP)(host=RemoteServerName)(port=1521))

)

(Connect_Data=(services_Name))

)’

其中protocol 是使用得访问协议;RemoteServerName是远程数据库的服务器名称或者IP, port是远程服务器里Oracle监视的端口(可以使另一个Oracle 数据库或者 Oracle Gateway,关于Oracle Gateway会在后续讲解)。 Services_Name是远程服务器提供的服务名称。 例如:远程服务器RemoteA,安装了Oracle Database ,它的监听端口是1521, 并且数据库服务的名称是orcl 则以上的语句改写如下:

Create database link dblinkName dblinkName connect to username identified by password using ‘NSNName=

(

Address_List=

(

(Adress=(protocol=TCP)(host=RemoteA)(port=1521))

)

(Connect_Data=(orcl))

)’

好了,以上简单的介绍了如何Oracle Database Link的类型和访问方式类型,及如何创建database link.

那么创建完,使用如下: (在访问权限满足的条件下)

Select * from remoteTableName@dblinkName

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

CREATE [PUBLIC] synonym_name

FOR [schema.]object_name[@database_link_name]

Synonym支持一下的对象:

•Tables

•Types

•Views

•Materialized views

•Sequences

•Procedures

•Functions

•Packages

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

Create public tableName for remoteTableName@dblinkName

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

Select * from tableName

上述语句等价于 Select * from remoteTableName@dblinkName


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10069570.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存