已知数据库的存放地址和名字,怎样在这些数据库中批量执行sql语句

liyaohui13098452233 2018-02-26 04:48:35
有两台服务器(局域网),一台服务器上有一个数据库A,表A1中存放着B服务器上的每个数据库的名称和地址,两台服务器上的数据库表结构是一致的

想在PB做一个小功能,从A服务器上的A1表中,读取每个数据库的地址和名次,批量在这些数据库中执行SQL语句。

...全文
560 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
吉普赛的歌 2018-02-26
  • 打赏
  • 举报
回复
没学过 PB , 但程序连接串基本都是差不多的内容: 1. 服务器 IP ; 2. SQL Server端口 ; 3. 数据库名称 ; 4. 用户名 ; 5. 密码 ; 6. 其它附加信息。 你所有的用户名和密码都是固定的 sa 及 *** ? 端口都是默认的 1433 ? 你首先要做的是在 ssms 中以上面 1-5 的参数来测试连接,能正常连接之后再来管程序的事情。 程序最终还是要实际连接执行的, 不要老在程序这里绕, 先做好准备工作。
  • 打赏
  • 举报
回复


Transaction 	lt_tran,lt_cus_tran
n_server  ln_Server
String		ls_userid, ls_dbname,ls_empid
long i,ll_count
string ls_customer,ls_khdz,ls_khdb

lt_tran=create Transaction
lt_cus_tran=create Transaction
ln_Server=create n_server

If ln_Server.of_connect( ls_dbname, lt_tran) = -1 Then  Return '2|连接数据库失败!'

select count(customerid) into :ll_count from b_customer using lt_tran;

select Customer,DBdress,DBName into :ls_customer,:ls_khdz,:ls_khdb from b_customer using lt_tran;

for i=1 to ll_count 
	
	// Profile ml
	lt_cus_tran.DBMS = "ADO.Net"
	lt_cus_tran.LogPass = '***'
	lt_cus_tran.LogID = "sa"
	lt_cus_tran.AutoCommit = False
	lt_cus_tran.DBParm = "Namespace='System.Data.OleDb',Provider='SQLOLEDB',DataSource='" + ls_khdz +"',Database='" + ls_khdb +"'"
	lt_cus_tran.Lock = 'RC'


	CONNECT Using lt_cus_tran;
	
	If lt_cus_tran.SQLCode <> 0 Then
		ln_Server.of_disconnect( lt_tran)
		Return '1|建立客户连接数据失败!'+ls_customer+'-'+string(lt_cus_tran.SQLCode)
	End If
	
	 execute immediate :ls_sql using lt_cus_tran;
	 
next 

 if lt_cus_tran.sqlcode=0 then
				ln_server.of_commit( lt_cus_tran)
				return '0|执行完毕!'
 else
				ln_server.of_rollback( lt_cus_tran)
				return '0|执行失败!'
 end if

destroy lt_tran
destroy lt_cus_tran
destroy ln_server

老是提示建立客户连接数据失败,如果我 if lt_cus_tran.sqlcode=0 then 这段放到for循环里去,只是第一个数据库执行了,第二个就不执行
吉普赛的歌 2018-02-26
  • 打赏
  • 举报
回复
这个不难吧, 写点伪码:
外循环,遍历每个库,得到连接串
BEGIN
	内循环,遍历需要执行的SQL(如果单个SQL中包含了GO,还得切分)
	BEGIN
		在当前库上执行对应的SQL
	END
END
二月十六 2018-02-26
  • 打赏
  • 举报
回复
读取A服务器上的A1表的数据,拼接成不同的数据库连接字符串,然后批量执行sql语句
以太坊是一个平台,它上面提供各种模块让用户来搭建应用,如果将搭建应用比作造房子,那么以太坊就提供了墙面、屋顶、地板等模块,用户只需像搭积木一样把房子搭起来,因此在以太坊上建立应用的成本和速度都大大改善。具体来说,以太坊通过一套图灵完备的脚本语言(Ethereum Virtual Machinecode,简称EVM语言)来建立应用,它类似于汇编语言。我们知道,直接用汇编语言编程是非常痛苦的,但以太坊里的编程并不需要直接使用EVM语言,而是类似C语言、Python、Lisp等高级语言,再通过编译器转成EVM语言。上面所说的平台之上的应用,其实就是合约,这是以太坊的核心。合约是一个活在以太坊系统里的自动代理人,他有一个自己的以太币地址,当用户向合约的地址里发送一笔交易后,该合约就被激活,然后根据交易的额外信息,合约会运行自身的代码,最后返回一个结果,这个结果可能是从合约的地址发出另外一笔交易。需要指出的是,以太坊的交易,不单只是发送以太币而已,它还可以嵌入相当多的额外信息。如果一笔交易是发送给合约的,那么这些信息就非常重要,因为合约将根据这些信息来完成自身的业务逻辑。合约所能提供的业务,几乎是无穷无尽的,它的边界就是你的想象力,因为图灵完备的语言提供了完整的自由度,让用户搭建各种应用。白皮书举了几个例子,如储蓄账户、用户自定义的子货币等。 2013年年末,以太坊创始人Vitalik Buterin发布了以太坊初版白皮书,启动了项目。2014年7月24日起,以太坊进行了为期42天的以太币预售。2016年初,以太坊的技术得到市场认可,价格开始暴涨,吸引了大量开发者以外的人进入以太坊的世界。国三大比特币交易所之二的火币网及OKCoin币行都于2017年5月31日正式上线以太坊。 [1] 自从进入2016年以来,那些密切关注数字货币产业的人都急切地观察着第二代加密货币平台以太坊的发展动向。作为一种比较新的利用比特币技术的开发项目,以太坊致力于实施全球去心化且无所有权的的数字技术计算机来执行点对点合约。简单来说就是,以太坊是一个你无法关闭的世界计算机。加密架构与图灵完整性的创新型结合可以促进大量的新产业的出现。反过来,传统行业的创新压力越来越大,甚至面临淘汰的风险。比特币网络事实上是一套分布式的数据库,而以太坊则更进一步,她可以看作是一台分布式的计算机:区块链是计算机的ROM,合约是程序,而以太坊的矿工们则负责计算,担任CPU的角色。这台计算机不是、也不可能是免费使用的,不然任何人都可以往里面存储各种垃圾信息和执行各种鸡毛蒜皮的计算,使用它至少需要支付计算费和存储费,当然还有其它一些费用。最为知名的是2017年初以摩根大通、芝加哥交易所集团、纽约梅隆银行、汤森路透、微软、英特尔、埃森哲等20多家全球top金融机构和科技公司成立的企业以太坊联盟。而以太坊催生的加密货币以太币近期又成了继比特币之后受追捧的资产。  智能合约的潜在应用很多。彭博社商业周刊称它是“所有人共享但无法篡改的软件”。更高级的软件有可能用以太坊创建网络商店。区块链程序以太坊可以用来创建去心化的程序、自治组织和智能合约,据纽约时报的报导,在2016年5月已经有数十个可用的程序。预期的应用目标涵盖金融、物联网、农田到餐桌(farm-to-table)、智能电网、体育,菠菜等。去心化自治组织有潜力让许多原本无法运行或成本过高的营运模型成为可能。较知名的应用有:去心化创业投资:The DAO用以太币资金创立,目标是为商企业和非营利机构创建新的去心化营业模式、The Rudimental让独立艺术家在区块链上进行群众募资。社会经济平台:Backfeed。去心化预测市场:Augur。物联网:Ethcore(一间以太坊公司)研发的客户端、Chronicled(一间区块链公司)发表了以太坊区块链的实物资产验证平台;芯片公司、物理IP创建者和生产者可以用植入的蓝牙或近场通信进行验证。Slock.It开发的智能锁可以在付费后自动打开,让用户在付费后可以帮电动车充电、或是打开租屋的房门。虚拟宝物交易平台:FreeMyVunk。版权授权:Ujo Music平台让创作人用智能合约发布音乐,消费者可以直接付费给创作人。伊莫珍·希普用此平台发布了一首单曲。智能电网:TransActive Grid让用户可以和邻居买卖能源。去心化期权市场:Etheropt。钉住汇率的代币:DigixDAO提供与黄金挂钩的代币,在2016年四月正式营运。Decentralized Capital提供和各种货币挂钩的代币。移动支付:Everex让外劳汇款回家乡。客户端软件以太坊的两个主要的客户端软件是Geth和Parity。企业软件企业软件公司也正测试用以太坊作为各种用途。已知有兴趣的公司包括微软、IBM、摩根大通。德勤和ConsenSys在2016年

27,579

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧