mgm6608美高梅app下载-mgm集团美高梅登录

mgm6608美高梅app下载以独家报道、社区、博客和专题策划等方式引领产业潮流,mgm集团美高梅登录为足球爱好者以及体育爱好者提供足球上网,让你无后顾之忧!,拥有多位香港乐坛红星。

却没有考虑到可以建立映射,同一台服务器跨库

日期:2020-04-01编辑作者:mgm集团美高梅登录
use master --打开master数据库,一般的创建语句都在master中执行.goif exists (select * from sysdatabases where name='CrossLibraryTable2') drop database CrossLibraryTable2 /*检查有没有这个数据库,如果有就删除它。*/gocreate database CrossLibraryTable2on primary(name='CrossLibraryTable2_data', ------------ 养成好习惯,数据文件加_datafilename='F:代码存放数据库CrossLibraryTable2_data.mdf', ------------ 一定要是.mdf的文件,代表主数据文件size=5mb, --默认数据库大小maxsize=100mb, --最大容量filegrowth=1mb --增长量)log on(name='CrossLibraryTable2_log', ------------ 养成好习惯,日志文件加_logfilename='F:代码存放数据库CrossLibraryTable2_log.ldf', ------------ 一定要是.ldf的文件,代表日志文件size=1mb, --默认数据库大小filegrowth=10% --增长量)

一. 前言

这个问题是上一篇文章《Oracle跨数据库实现定时同步指定表中的数据》中所提问题的进一步延伸。考虑到对数据的实时性要求比较高,设置成定时同步,有点不妥,需要改善升级更改为实时同步。

下面介绍到的方式,严格意义上说,并没有实现实时同步。是通过Oracle数据库创建同义词+DBlink的方式,来建立远程映射。在查看数据时,直接去远程查询源库中的表。

而我一直关注的是如何进行同步数据,却没有考虑到可以建立映射。另外,还有一点就是需要交代,就是同步到目标数据库中的表,不进行增删改操作,只进行查询的操作,这也是可以使用同义词方式解决问题的关键。

这种解决思路的出现,多亏了在CSDN问答时,热心网友的回答,下面就是问题详情描述。

复制代码 代码如下:CREATE PUBLIC DATABASE LINK 数据链名称 CONNECT TO 登陆用户名 IDENTIFIED BY 密码 USING '(DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 对方Oracle服务器的IP地址)(PORT = 端口号)) ) (CONNECT_DATA =(SERVICE_NAME = 对方Oracle服务器服务名) ) )'

同一台服务器跨库访问实现

下面详细模拟一下整个实验测试的过程:

$ORACLE_HOME/network/admin/tnsnames.ora

 use CrossLibraryTable1 create table CrossTest1( Id int primary key identity, Name nvarchar(20) )
(1)首先在Oracle_A端创建一个对table_A只有查询功能的用户
<1> 创建用户
  sqlplus /nolog
  conn /as sysdba;
  create user username identified by password;

<2> 查看所有的用户列表
    用户创建完成后,查看用户是否创建成功
  select * from all_users;

<3>授予权限
    为了能够保证能够登陆,必须赋予如下权限

  --授予username用户创建session的权限,即登陆权限
  grant create session to username;

  --授予username用户使用表空间的权限
  grant unlimited tablespace to username;

  --oracle对权限管理比较严谨,普通用户之间也是默认不能互相访问的,需要互相授权.
  --如果scott用户要授权给username用户查看自己的test表的权限;
  sqlplus scott/tiget@localhost:1521/orcl

  --授予username用户查看指定的权限
  grant select on test to username;

  --撤销权限
    基本语法同grant,关键字为revoke;

第一步、配置A服务器端的tnsnames.ora文件,该文件存放的位置为:

2.接下来在两个数据库里面分别创建一个CrossTest1和一个CrossTest2表用于跨库查询

(4)在Oracle_B端创建同义词
<1> 使用sqlplus登录自己的用户
sqlplus tianzhi_smart/tianzhi_smart@localhost:1521/orcl

<2> 创建同义词
create or replace public synonym TEST1130 for scott.TEST@db32;

<3> 查询测试
select * from TEST1130;
可以看到这与在Oracle_A源数据库中查到的table_A表中的数据一样.

注意事项:
当远程查询的数据库中包含BLOB字段时,会报出如下错误.

**ORA-22992: 无法使用从远程表选择的 LOB 定位器 **

当出现这个错误的时候,那是因为跨库连接查询中的表中存在BLOB类型的字段,所以一定要注意,所有表中存在blob类型字段,

  1. 不能用 select * from 连接的表
  2. 不能将blob类型的字段出现在脚本中。

如果这些blob类型的字段一定要导过来,可以先建立临时表再插入本地表,方法如下.在pl/sql中执行

第一步 建临时表
create global temporary table foo ( X BLOB )
on commit delete rows;
第二步 插入本地表
insert into foo select blobcolumn from remoteTable@dl_remote ;

第二步、在A服务器的一个库中建立B的一个数据的DBLINK。语法如下:

--创建CrossLibraryTable1脚本:

四. 学习心得

添加如下行,其中DBLINK为连接名,HOST和PORT为数据库侦听的IP及端口,SERVICE_NAME为数据库的SID,

我们经常会遇到一个数据库要访问另一个数据库,或者一台服务器要访问另一台服务器里面的数据库。 那么这个如何实现的呢? 相信看完这篇文章你就懂了!

三. 采用同义词+DB_Link的方式结果步骤

之所以能够选择采用同义词的方式,处理这个问题。主要还是源于在问题描述中提到一个点,那就是我们只需要对同步后的表进行查询操作。这点是使用同义词方式的重要要素。

select owner, db_link from dba_db_links;

  1. 首先创建两个数据库CrossLibraryTable1,CrossLibraryTable2
(3)创建远程连接DB_Link
<1> 创建远程连接 db_link
create public database link db32 connect to tianzhi_test identified by "tianzhi_test" using '192.168.56.6:1521/ORCL'

<2> 测试远程连接是否成功
select * from tianzhi_smart.zh_item_news@db32;

第三步.使用链接的数据库 3.1 查询、删除和插入数据和操作本地的数据库是一样的,只不过表名需要写成“表名@database link名”,如 select * from table_name@MEDIADB ; 3.2 也可以为这个表创建一个同义词 create synonym aaa for table_name@MEDIADB ; 如下语句的效果和3.1中的一样 select * from aaa; 删除同义词的语句为 drop synonym aaa;

PS:像上面那样是可以进行查询,然而在项目中使用上面的代码格式就会引发一些问题,那什么问题呢?比如另一个数据库的名称改变了,我们就需要把所有用到这个的地方都得改掉,这样就很麻烦,那么有什么解决方案么,使得改一处就好了?当然有,用数据库同义词就可以轻松搞定!

(1) 在提问题时,要具有以下三个关键点:

A.简洁;B.全面;C.系统
这三点,其实也是今晚参加拆书帮线下分享活动,拆书家拆解分享的一个片段。现学现卖,直接拿过来结合我的问题进行阐述。

其实上午这种问题,我采用了两种方式进行了询问求助,一种是微信语音的方式,还有就是发帖的方式。而在语言提问方面,自己却严重的违反了上面的三条,而在发帖提问中,却注意到了这三点。这也是提醒我,以后要多多注意语言表达的一个点。

执行如下查询语句,其中MEDIADB为database link名,MEDIADBLINK为先前在tnsnames.ora中定义的连接名, dbuser为用户名,password为密码

use CrossLibraryTable1 insert into CrossTest1 values('跨库1测试数据1') insert into CrossTest1 values('跨库1测试数据2') use CrossLibraryTable2 insert into CrossTest2 values('跨库2测试数据1') insert into CrossTest2 values('跨库2测试数据2')
我原来的处理方式:

通过建立远程连接DBLink+JOB定时任务+存储过程的方式,实现了定时同步更新,但不能做到实时同步

SQL CREATE USER AAA IDENTIFIED BY 1;CREATE USER AAA IDENTIFIED BY 1 *ERROR 位于第 1 行:ORA-00988: 缺少或无效口令

本文由mgm6608美高梅app下载发布于mgm集团美高梅登录,转载请注明出处:却没有考虑到可以建立映射,同一台服务器跨库

关键词:

date 参数是合法的日期,(1)MySql查询数据库当前

一,写在前面的话 select DATE_FORMAT(create_time,'%Y%u') weeks,count(caseid) count from tc_case group by weeks; select DATE_FORMAT(create_time,'...

详细>>

下表中无索引及主键,这次产品妹子来新需求了

例如 DataIDE之ODPS_SQL节点 因为大同小异,所以这里我们仅以销售数据的统计节点为例进行讲解。如下图: 渠道销售数...

详细>>

mgm集团美高梅登录:我们希望在一行中显示周一

在数据库操作中,有些时候我们遇到需要实现“行转列”的需求,例如一下的表为某店铺的一周收入情况表: WEEK_I...

详细>>

下面为从MySQL数据库读取图片和向数据库插入图片

mgm6608美高梅app下载,使用SQL语句从电脑导入图片到数据库的方法,具体代码如下所示: 1 介绍 MySQL 数据库优化全攻略...

详细>>