- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个类,其中包含我的 ASP.NET 4.0 应用程序的所有数据访问代码。类中有两种方法可以将数据插入数据库。我想在 SqlTransaction 中加入这些插入,并在其中一个插入失败时回滚事务。但是,由于我的编码方式,我不确定该怎么做。这是我的数据访问代码:
public class DBUtil
{
private static readonly string _connectionString;
static DBUtil()
{
_connectionString = WebConfigurationManager.ConnectionStrings["MooDB"].ConnectionString;
if (string.IsNullOrEmpty(_connectionString))
throw new Exception("Connection string not configured in Web.Config file");
}
public int InsertTrade(
string symbol,
string tradeSetupId,
int tradeTypeId,
decimal lotsPerUnit,
string chartTimeFrame,
decimal pctAccountRisked,
int? tradeGrade = null,
int? executionGrade = null,
int? MFEPips = null,
int? MAEPips = null
)
{
SqlCommand cmd = new SqlCommand("usp_InsertTrade");
// required parameters
cmd.Parameters.AddWithValue("@symbol", symbol);
cmd.Parameters.AddWithValue("@tradeSetupId", tradeSetupId);
cmd.Parameters.AddWithValue("@tradeTypeId", tradeTypeId);
cmd.Parameters.AddWithValue("@lotsPerUnit", lotsPerUnit);
cmd.Parameters.AddWithValue("@chartTimeFrame", chartTimeFrame);
cmd.Parameters.AddWithValue("@pctAccountRisked", pctAccountRisked);
// optional parameters
if (MAEPips.HasValue)
cmd.Parameters.AddWithValue("@MAEPips", MAEPips);
if (MFEPips.HasValue)
cmd.Parameters.AddWithValue("@MFEPips", MFEPips);
if (tradeGrade.HasValue)
cmd.Parameters.AddWithValue("@tradeGrade", tradeGrade);
if (executionGrade.HasValue)
cmd.Parameters.AddWithValue("@executionGrade", executionGrade);
return (InsertData(cmd, "trade"));
}
public int InsertOrder(
int tradeId,
int units,
string side,
decimal price,
decimal spread,
int strategyId,
string signalTypeId,
int brokerId,
string orderTypeId,
DateTime orderDateTime,
string comment,
int? accountId = null
)
{
SqlCommand cmd = new SqlCommand("usp_InsertOrder");
// required parameters
cmd.Parameters.Add(new SqlParameter("@tradeId", tradeId));
cmd.Parameters.Add(new SqlParameter("@units", units));
cmd.Parameters.Add(new SqlParameter("@side", side));
cmd.Parameters.Add(new SqlParameter("@price", price));
cmd.Parameters.Add(new SqlParameter("@spread", spread));
cmd.Parameters.Add(new SqlParameter("@strategyId", strategyId));
cmd.Parameters.Add(new SqlParameter("@signalTypeId", signalTypeId));
cmd.Parameters.Add(new SqlParameter("@brokerId", brokerId));
cmd.Parameters.Add(new SqlParameter("@orderTypeId", orderTypeId));
cmd.Parameters.Add(new SqlParameter("@orderDateTime", orderDateTime));
cmd.Parameters.Add(new SqlParameter("@comment", comment));
// optional parameters
if (accountId.HasValue)
cmd.Parameters.Add(new SqlParameter("@accountId", accountId));
return (InsertData(cmd, "order"));
}
private int InsertData(SqlCommand cmd, string tableName)
{
SqlConnection con = new SqlConnection(_connectionString);
cmd.Connection = con;
cmd.CommandType = CommandType.StoredProcedure;
int rc = -1;
try
{
con.Open();
rc = (int) cmd.ExecuteScalar();
}
finally
{
con.Close();
}
return rc;
}
}
我正在像这样从我的 ASP.NET 页面访问该代码:
int tradeId = DB.InsertTrade (
ddlSymbols.SelectedValue,
ddlTradeSetups.SelectedValue,
int.Parse(ddlTradeTypes.SelectedValue),
decimal.Parse(txtLotsPerUnit.Text),
ddlTimeFrames.Text,
decimal.Parse(txtAcctRisk.Text));
int orderId = DB.InsertOrder (
tradeId,
int.Parse(txtUnits.Text),
radSide.SelectedValue,
Decimal.Parse(txtEntryPrice.Text),
Decimal.Parse(txtSpread.Text),
int.Parse(ddlStrategies.SelectedValue),
"IE",
int.Parse(ddlBrokers.SelectedValue),
radSide.SelectedValue + radOrderType.SelectedValue,
DateTime.Parse(txtEntryDate.Text + " " + txtEntryTime.Text),
txtEntryComments.Text,
int.Parse(ddlAccounts.SelectedValue));
我想要做的是将来自 ASP.NET 页面的调用包装在 SqlTransaction 中。做这个的最好方式是什么?我是否需要稍微重构我的代码?
非常感谢。
最佳答案
使用 TransactionScope
反对在一个事务中放置多个语句:
using (TransactionScope scope = new TransactionScope())
{
// Database call 1 - within transaction
// Database call 2 - within same transaction
scope.Complete(); // Commit the transaction, or face an automatic rollback
}
关于c# - 如何将这些调用放在 SqlTransaction 中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4124477/
使用 SQLTransaction 的合适时间是什么时候? 我将它们用于我所有的 INSERT、UPDATE 和 DELETE 语句。 这是正确的用法还是我做得有点矫枉过正? 最佳答案 当您希望以原子
这里有一些背景:我们的站点会定期崩溃,以至于不得不重新启动 IIS;这几乎总是在修补 DLL 后的一个小时内发生(我们使用网站项目,而不是 Web 应用程序项目,因此每个 ASPX 页面都是一个单独的
我的应用程序中有一次出现以下错误。 This SQLTransaction has completed; it is no longer usable Stack Trace 附在下面 – 它说明了
所以我有一个PatientInfo表,我只需点击一个按钮就可以插入一个患者。。同样的按钮会生成患者的ID,但出于某种原因,如果我运行计时器同时从5个应用程序执行此代码,则只有一个应用程序会通过,而其他
所以我有一个PatientInfo表,我只需点击一个按钮就可以插入一个患者。。同样的按钮会生成患者的ID,但出于某种原因,如果我运行计时器同时从5个应用程序执行此代码,则只有一个应用程序会通过,而其他
我需要在 SqlTransaction 的 finally block 中调用 dispose 吗?假装开发人员没有在任何地方使用 USING,然后尝试/捕获。 SqlTransaction sqlT
我们有一个有趣的设置,我们将 SqlTransactions 持久化到 Web 应用程序的应用程序内存中。我们正在考虑将我们的 Web 应用程序移动到 NLB 场景中,因此我们需要一种方法使这些事务不
一旦事务开始,是否可以延长事务的超时(使用 SQL Server)? 最佳答案 超时对于 SQL Server 来说是“外部”的,因此 SQL Server 不会影响它。 不幸的是,“不” 关于.ne
我在此网站上找到了以下引用:“建议您使用 TransactionScope 类创建隐式事务”:http://msdn.microsoft.com/en-us/library/system.transa
我很好奇以下代码是否被认为是安全的? using (SqlConnection cn = new SqlClient.SqlConnection(connectionString)) { cn.
我有一个类,其中包含我的 ASP.NET 4.0 应用程序的所有数据访问代码。类中有两种方法可以将数据插入数据库。我想在 SqlTransaction 中加入这些插入,并在其中一个插入失败时回滚事务。
我有一个循环,我在其中调用具有不同参数值的存储过程。接下来调用 cmd.ExecuteNonQuery();我使用事务来保存全部或回滚,并使用 checkBox2 - 始终保存。我发现了一个问题,但找
前几天研究了SqlTransaction,知道了SqlTransaction.Commit()的用途——应该是“提交数据库事务”。 -MSDN。 但是它是如何工作的? 例如:我写了一段代码是这样的:
我在我的代码中使用 SqlTransaction 来实现回滚目的。在交易中,我得到了多个要执行的语句,可能包括选择插入和更新。所有这些语句都在 sqltransaction 的范围内。一切正常只针对一
我遇到了一个问题,即使没有任何查询引发异常,所做的更改也会被回滚。这很奇怪,因为代码在一个环境中工作但不在另一个环境中提交更改。 这是处理事务的函数。当我在提交上放置一个断点时,我点击了提交,我可以看
我正在尝试以异步方式提交/回滚 SqlTransaction。但看起来不支持异步。有什么方法可以在不使用原始 SQL 启动事务的情况下使其异步? 最佳答案 看起来不像。通过相关代码,所有其他方法都是异
我要开始说我很确定这是不可能的。谷歌搜索没有发现任何人问这个问题,所以我悲观地希望。 我正在使用 SqlTransaction 连接到数据库,并在我关闭它之前允许多个消费者使用该事务。是否可以确定事务
我有两个存储过程,我想在一个事务中执行它们。由于各种原因,我需要在我的应用程序代码中而不是在数据库中处理事务。 目前,我的代码如下所示: try { using (SqlConnection
我有以下使用 SqlTransaction 的代码。我已经在 catch 和 finally block 中调用了 dispose。但是我没有在调用 Dispose() 之前检查它是否已经被处理。我们
所以我有多个 SqlConnections,我希望它们全部用于一个 SqlTransaction。我知道我可以只使用一个连接,但最终在每个连接中都有大量新声明和无用的(连接完成后)变量,我需要程序尽可
我是一名优秀的程序员,十分优秀!