mysql存储过程中怎么进行跨库操作?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql存储过程中怎么进行跨库操作?相关的知识,希望对你有一定的参考价值。

set tablename :=(select tname from people);
set tabletime :=(select CONCAT_WS('_',tablename,time));
set dbname :=(select dname from people);
set @s=concat('alter table ',dbname.tablename,' rename to ',dbname.tabletime);
PREPARE str from @s;
EXECUTE str;

结果:
ERROR 1109 (42S02): Unknown table 'dbname' in field list 该怎么使用第二个库呢 又不能直接写use

参考技术A   傻孩子, 你不能直接dbname.tablename 这样写, 你得先把他们concat起来, 因为他们是变量呀

  set @s=concat('alter table ',concat(dbname, '.', dablename),' rename to ',concat(dbname, '.', tabletime
));
参考技术B 如果库不在同一个mysql上 只能通过开发语言来实现相互通讯追问

是在同一个服务器上,但是这个有不同的库不同的表,所以您帮忙想一下 有处理的方法吗?

追答

我前面估计没有给你说清楚..只要是跨库操作都需要用开发语言协助。

参考技术C 先建立个视图! 在视图里跨库连表! 然后 在 存储过程中使用视图就可以了

SQL Server 跨库同步数据

原文:SQL Server 跨库同步数据

  最近有个需求是要跨库进行数据同步,两个数据库分布在两台物理计算机上,自动定期同步可以通过SQL Server代理作业来实现,但是前提是需要编写一个存储过程来实现同步逻辑处理。这里的存储过程用的不是opendatasource,而是用的链接服务器来实现的。存储过程创建在IP1:192.168.0.3服务器上,需要将视图v_custom的客户信息同步到IP2:192.168.0.10服务器上的t_custom表中。逻辑是如果不存在则插入,存在则更新字段。

技术分享

    

 1 create PROCEDURE [dbo].[p_pm_项目平台客户批量同步到报销平台](
 2     @destserver nvarchar(50),
 3     @sourceserver nvarchar(50)
 4 )
 5 AS
 6 BEGIN
 7 
 8     SET NOCOUNT ON;
 9     --不存在则添加链接服务器,外部查询必须指明IP地址,例如 select * from [IP].[database].[dbo].[table]
10     if not exists (select * from sys.servers where server_id!=0  and data_source=@destserver)
11     begin
12         exec sp_addlinkedserver    @server=@destserver
13     end
14     if not exists (select * from sys.servers where server_id!=0  and data_source=@sourceserver)
15     begin
16         exec sp_addlinkedserver    @server=@sourceserver
17     end
18         begin try  
19         set xact_abort on
20         begin transaction 
21             --http://www.cnblogs.com/chnking/archive/2007/04/04/699891.html 
22                 INSERT INTO [192.168.0.10].[dbCRM].[dbo].[t_custom] (客户ID,
23                                 
24                                 客户名称,
25                                 客户简称,
26                                 输入码,
27                                 查询码,
28                                 地址,
29                                 录入登录名,
30                                 录入时间,
31                                 修改登录名,
32                                 修改时间,
33                                 审批状态ID,
34                                 审批状态名称,
35                                 是否审批结束,
36                                 审批操作时间,
37                                 项目管理客商编码,
38                                 序号)
39                 SELECT A.客户ID,A.客户名称,
40                                 A.客户简称,
41                                 dbo.fn_pm_GetPy(A.客户名称),
42                                 A.客户编号+,+A.客户名称+,+dbo.fn_pm_GetPy(A.客户名称)+,+A.客户简称+,+dbo.fn_pm_GetPy(A.客户简称),
43                                 A.地址,
44                                 admin,
45                                 getdate(),
46                                 null,
47                                 null,
48                                 D65F87A8-79C8-4D1C-812D-AE4591E056A8,
49                                 已审批,
50                                 1,
51                                 A.审批操作时间,
52                                 A.项目管理客商编码,
53                                 0
54                 FROM   [dbPM].[dbo].[v_custom] A
55                 WHERE  A.客户ID NOT IN ( SELECT 客户ID FROM   [192.168.0.10].[dbCRM].[dbo].[t_custom]);
56             
57                                                     
58                                                                                     
59                 ----------------------------------存在更新-----------------------------------                                                                
60                 update   A  set  
61                             A.客户名称=B.客户名称,
62                             A.客户简称=B.客户简称,
63                             A.输入码=dbo.fn_pm_GetPy(B.客户名称),
64                             A.查询码=B.客户编号+,+B.客户名称+,+dbo.fn_pm_GetPy(B.客户名称)+,+B.客户简称+,+dbo.fn_pm_GetPy(B.客户简称),
65                             A.地址=B.地址,
66                             A.修改登录名=admin,
67                             A.修改时间=getdate(),
68                             A.项目管理客商编码 =B.项目管理客商编码
69                     from  [192.168.0.10].[dbCRM].[dbo].[t_custom] A,[dbPM].[dbo].[v_custom]  B 
70                     where A.客户ID=B.客户ID;
71             
72             
73             
74             commit transaction 
75         end try 
76         begin catch 
77             select ERROR_NUMBER() as errornumber,ERROR_MESSAGE() as errormsg,ERROR_LINE() as errorline
78             rollback transaction 
79         end catch
80 END

  如果没有正确配置,经常会出现 消息 7391,级别 16,状态 2,过程 xxxxx,第 XX 行 。无法执行该操作,因为链接服务器 "xxxxx" 的 OLE DB 访问接口 "SQLNCLI" 无法启动分布式事务。

  可以参照如下的配置:

技术分享

 具体可以参看:http://www.cnblogs.com/chnking/archive/2007/04/04/699891.html 

以上是关于mysql存储过程中怎么进行跨库操作?的主要内容,如果未能解决你的问题,请参考以下文章

sql server service broker中调用存储过程执行跨库操作,不管怎么设置都一直提示 服务器主体 "sa" 无法在当前安全上下文下访问数据库 "dbnam

oracle存储过程里调用存储过程

oracle 怎么调用存储过程

oracle中,一个存储过程怎么调用另一个存储过程?

qt调用oracle存储过程,该怎么处理

数据库存储过程和视图一般啥时候用