我需要从MS SQL服务器通过ODBC向Oracle服务器提交一系列查询,并将结果作为表存储在MS SQL服务器上。
它必须是直通,因为查询需要在Oracle服务器上定义的服务器端函数。我不能将表保存在Oracle服务器上,然后通过ODBC访问它,因为Oracle上运行的数据库的供应商有许可限制。
下面是返回正确结果的代码,但我不知道如何保存它们:
DECLARE @BibID AS bigint
DECLARE BibList CURSOR FOR
SELECT BIB_ID FROM tblActiveSerialsThatHave740s
OPEN BibList
FET
Java 中,原生 JDBC 执行 TDSQL 批量更新的时候,proxy 报错,报错内容理解为:in a non XA transaction,this sql use a different set。
官网 TDSQL 文档中,我看到 update 语句允许跨 set 更新的,update 语句 where 条件加上了 shardkey 的条件了。
求问,有人知道该如何操作嘛?
我有一个SQL Server 2008 RDS实例,我在本地计算机SQL server 2014上创建了一个链接服务器(AWSMSSQL)。
现在,我从本地计算机数据库表中创建了insert、update和delete触发器
USE [test]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TRIGGER [dbo].[ms_test] ON [dbo].[localservertable]
FOR INSERT, UPDATE, DELETE
AS
BEGIN
declare @iddata int;
我使用的源代码如下:
Database db1 = new Database(); //init 1 db connection
db1.BeginTransaction();
//this function used to check exist customer
//in this function, I also use Database db2 = new Database(); db2.Close();
CheckExistCustomer();
InsertCustomer(db1, strInsert); //this function worked correct, use
我想在Server1.DB1中执行一个存储过程,这个存储过程将在另一个使用动态SQL的存储过程中执行,它将在Server1.DB2中执行。
我需要使用begin/end transaction来确保所有东西都执行了,否则所有东西都失败了。
问题是:在这种情况下,使用指向不同数据库的动态SQL,事务可以工作吗?
喜欢
BEGIN TRANSACT
--Set Status to "In Progress"
SET @Qry = N'EXEC '+ @DB2 + '.[dbo].[StatusUpdate] @Id, @Status
我正在进行一个项目,在这个项目中,我有多个存储库,可以从不同的表中获取数据。我的所有存储库都是独立的,它们创建新的dataContext,将行添加到表中,并应用提交更改命令。现在,如果在我的服务中,有一种情况,我必须将数据插入多个表,但它应该发生在一个事务中。我可以使用TrnasctionScope实现这一点,但这需要相同的dataContext。由于我使用StrucutreMap创建对象,因此无法获得相同的数据上下文,因此事务失败。
我的对象是这样的。
interface IConnection
{
MyDataContext GetContext();
}
public class C
我有一个结构,设置了对服务器上的WCF服务的多个服务调用。我每个调用都实例化了多个DbContexts。我希望将这些调用中的一些分组到服务器上的单个事务中,同时排除可能在同一时间发生的其他调用。这个是可能的吗?
我的上下文都是在单个服务器上的单个应用程序中管理的,并且所有上下文都使用相同的连接字符串。
我在找像这样的东西
var transKey = transService.BeginTransaction(); // creates a transaction of some kind.
service1.Execute(transKey); // on the server places
有人能告诉我如何在PostgreSQL上执行分布式事务吗?
我需要启动从节点x到节点y的事务(这个节点有一个数据库)。但是我在网上找不到我该怎么做的信息。
我所能做的就是一个分布式查询:
select dblink_connect
('conn','dbname=ConsultaRemota host=192.168.3.9
user=remoto password=12345 port=5432');
select * from dblink('conn','select * from tablaremota') as
t
我尝试在循环中使用事务作用域。整个循环使用到数据库的单个连接进行。我使用entity Framework4进行数据库访问。在循环的第二次迭代期间,当LINQ to Entites查询执行时,将引发异常,声明服务器上的MSDTC不可用。
我读到过显式地打开连接然后征募事务应该可以解决这个问题,但事实并非如此。下面的示例代码反映了正在发生的基本操作。
对如何防止升级到MSDTC有什么建议吗?
Using context = New MyEntities()
Dim connection = context.Connection
connection.Open()
For
在我们的本地服务器上从未见过这种情况,但在将MVC4应用程序和SQL Server数据库部署到Azure后,我们有时会收到以下异常,如何解决此问题?
[ArgumentException: Value does not fall within the expected range.]
System.Transactions.Oletx.IDtcProxyShimFactory.ConnectToProxy(String nodeName, Guid resourceManagerIdentifier, IntPtr managedIdentifier, Boolean& nodeNam
我在本地数据库中的SQL表上有一个非常简单的触发器。触发器看起来像这样:
ALTER TRIGGER [dbo].[trg_UpdateAzureDB]
ON [dbo].[my_local_table]
AFTER INSERT,DELETE,UPDATE
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
-- Insert statements for trig
我有一个要通过链接服务器执行的查询。该查询如下所示:
USE db1;
SET xact_abort ON;
DECLARE @statement NVARCHAR(max);
SET @statement = 'EXECUTE (''INSERT INTO T1(V1, V2) VALUES (1, 2)'') AT LS1';
BEGIN try
BEGIN TRANSACTION
EXEC Sp_executesql @statement
COMMIT TRANSACTION
END try
BEGIN
这是可行的,返回一个结果集:
exec ('select ''col'', count(1) from test.dbo.[Table1] with (nolock)') at svrA
当我尝试将结果集插入到表中时:
insert into rowcount_sub (tablename,rowcnt)
exec ('select ''col'', count(1) from test.dbo.[Table1] with (nolock)') at svrA
给出此错误的失败:
OLE DB pr
我已经在Server上创建了一个“后插入”触发器。
USE [CSPFContactCenter]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER TRIGGER [dbo].[SendSMS_INSERT]
ON [dbo].[tblSmsSend]
AFTER INSERT
AS
BEGIN
declare @Text nvarchar(max)
declare @MobileNumber nvarchar(max)
set @Text = (SELECT TOP 1 Text FROM tblSmsSe