sql事务的调用

一、数据库的SQL

USE [Text]
GO
/****** Object: StoredProcedure [dbo].[mon] Script Date: 2017-01-03 15:59:28 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER proc [dbo].[mon]

@toID int, --接收转账的账户

@fromID int , --转出自己的账户

@momeys money, --转账的金额

@back int output,--返回值

@frommomeys money output,--转出方金额

@tomomeys money output--接收方金额

as

begin tran --开始执行事务

update bb set [email protected] where [email protected] --执行的第一个操作,转账出钱,减去转出的金额

select @frommomeys=moneys from bb where [email protected]转出后金额

update bb set [email protected] where [email protected] --执行第二个操作,接受转账的金额,增加

select @tomomeys=moneys from bb where [email protected]转出后金额

if @@error<>0 --判断如果两条语句有任何一条出现错误

begin rollback tran --开始执行事务的回滚,恢复的转账开始之前状态

set @back=1 --返回1失败
return

end

else --如何两条都执行成功

begin commit tran 执行这个事务的操作

set @back=0 --返回0成功
return

end

二、事务调用

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace SQL事务
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}

private void button1_Click(object sender, EventArgs e)
{
SqlConnection con = new SqlConnection(@"Data Source=.;database=Text;uid=sa;pwd=123456"); //连接字符串

SqlCommand cmd = new SqlCommand("mon", con); //调用存储过程

cmd.CommandType = CommandType.StoredProcedure;

con.Open();

SqlParameter prar = new SqlParameter();//传递参数

cmd.Parameters.AddWithValue("@fromID", textBox2.Text);

cmd.Parameters.AddWithValue("@toID", textBox3.Text);

cmd.Parameters.AddWithValue("@momeys", Convert.ToInt32(TextBox1.Text));

cmd.Parameters.Add("@back", SqlDbType.Int).Direction = ParameterDirection.Output;

cmd.Parameters.Add("@frommomeys", SqlDbType.Money).Direction = ParameterDirection.Output;

cmd.Parameters.Add("@tomomeys", SqlDbType.Money).Direction = ParameterDirection.Output;

cmd.ExecuteNonQuery();

string value = cmd.Parameters["@back"].Value.ToString();//把返回值赋值给value

from_money.Text =Convert.ToInt32(cmd.Parameters["@frommomeys"].Value).ToString();//获取转方剩余金额

to_money.Text = Convert.ToInt32(cmd.Parameters["@tomomeys"].Value).ToString();//获取到方金额

if (value == "0")
{

Label1.Text = "添加成功";

}

else
{

Label1.Text = "添加失败";

}
}

private void button2_Click(object sender, EventArgs e)
{
SqlConnection con = new SqlConnection(@"Data Source=.;database=Text;uid=sa;pwd=123456");

con.Open();

SqlTransaction tran = con.BeginTransaction();//先实例SqlTransaction类,使用这个事务使用的是con 这个连接,使用BeginTransaction这个方法来开始执行这个事务

SqlCommand cmd = new SqlCommand();

cmd.Connection = con;

cmd.Transaction = tran;

try
{

//在try{} 块里执行sqlcommand命令,

cmd.CommandText = "update bb set moneys=moneys-‘" + Convert.ToInt32(TextBox1.Text) + "‘ where ID=‘" + textBox3.Text + "‘";

cmd.ExecuteNonQuery();

cmd.CommandText = "update bb set moneys=moneys+‘" + Convert.ToInt32(TextBox1.Text) + "‘ where ID=‘" + textBox2.Text + "‘";

cmd.ExecuteNonQuery();

tran.Commit();//如果两个sql命令都执行成功,则执行commit这个方法,执行这些操作

Label1.Text = "添加成功";

}

catch
{

Label1.Text = "添加失败";

tran.Rollback();//如何执行不成功,发生异常,则执行rollback方法,回滚到事务操作开始之前;

}

}
}
}

时间: 2024-12-28 09:19:53

sql事务的调用的相关文章

Android学习---SQLite数据库的增删改查和事务(transaction)调用

上一篇文章中介绍了手工拼写sql语句进行数据库的CRUD操作,本文将介绍调用sqlite内置的方法实现CRUD操作,其实质也是通过拼写sql语句. 首先,创建一个新的android项目: 其次,查看代码实现增删查改: 1.创建DB工具类 MyDBHelper.java(创建数据库的操作) package com.amos.android_db; import android.content.Context; import android.database.sqlite.SQLiteDatabas

SQL 事务

首先声明,以下是个人见解,如有错误望指出,先谢谢! 我们知道数据库(SQL) 的事务,现在我讲讲我的大概了解: 数据库的事务使用基本语法: begin try begin tran [tranName] --语句 commit tran [tranName] end try begin catch rollback tran [tranName] end catch [] 表示可有可无, try catch 我就不说了. 数据库执行事务成功与否 看的是计数,即 begin tran  和 com

sql事务(Transaction)用法介绍及回滚实例

事务是将一系列操作作为一个单元执行,要么成功,要么失败,回滚到最初状态.在事务处理术语中,事务要么提交,要么中止.若要提交事务,所有参与者都必须保证对数据的任何更改是永久的.不论系统崩溃或是发生其他无法预料的事件,更改都必须是持久的.只要有一个参与者无法做出此保证,整个事务就会失败.事务范围内的所有数据更改将回滚到特定设置点. Begin TRANSACTION 语句1; If @@error<>0 Goto error 语句2; If @@error<>0 Goto error

sql事务和存储过程

一.sql事务 1.什么是事务:事务是一个不可分割的工作逻辑单元,在数据库系统上执行并发操作时事务是做为最小的控制单元来使用的.他包含的所有数据库操作命令作为一个整体一起向系提交或撤消,这一组数据库操作命令要么都执行,要么都不执行. 2.事务的语句开始事物:BEGIN TRANSACTION提交事物:COMMIT TRANSACTION回滚事务:ROLLBACK TRANSACTION 3.事务的4个特性  ①原子性(Atomicity):事务中的所有元素作为一个整体提交或回滚,是不可折分的,事

sql事务(Transaction)用法介绍及回滚实例_转

sql事务(Transaction)用法介绍及回滚实例 事务(Transaction)是并发控制的单位,是用户定义的一个操作序列.这些操作要么都做,要么都不做,是一个不可分割的工作单位.通过事务,SQL Server能将逻辑相关的一组操作绑定在一起,以便服务器保持数据的完整性 当对多个表进行更新的时候,某条执行失败.为了保持数据的完整性,需要使用事务回滚. 显示设置事务 代码如下 begin try   www.2cto.com begin transaction insert into shi

SQL事务日志备份时的问题

1.在进行事务日志备份的时候,如下图: 3041 消息的疑难解答时的考虑事项:不会只是一个数据库或所有数据库出现问题吗?是备份到本地存储区或远程存储吗?哪种类型的备份 (数据库备份. 日志备份和差异备份) 是否出现故障?正在执行备份的应用程序 (SQL Server 代理作业. SQL 维护计划或 VDI/VSS 备份软件供应商提供的备份代理程序) 是什么?用于备份命令的选项是什么?什么是在其下运行 SQL Server 的帐户,此帐户没有所需的访问目标位置写入文件? 参考:http://sup

SQL—— 事务

SQL 事务: 1.  定义: 事务是作为单个逻辑单元执行的一系列操作. 多个操作作为一个整体向系统提交,要么执行.要么都不执行,事务是一个不可分割的工作逻辑单元.这特别适用于多用户同时操作的数据通信系统.例如:订票.银行.保险公司以及证券交易系统等. 2. 事务必须具备的特性: 1) 原子性:  Atomicity  :事务是一个完整的操作, 个元素是不可再分的.事务中所以元素必须作为一个整体提交或回滚.如果十五中任何元素失败,则整个事务将失败. 2)一致性: Consistency: 当事务

sql 事务日志传输

原文:sql 事务日志传输 概述 可以使用日志传送将事务日志不间断地从一个数据库(主数据库)发送到另一个数据库(辅助数据库).不间断地备份主数据库中的事务日志,然后将它们复制并还原到辅助数据库,这将使辅助数据库与主数据库基本保持同步.目标服务器充当备份服务器,并可以将查询处理从主服务器重新分配到一个或多个只读的辅助服务器.日志传送可与使用完整或大容量日志恢复模式的数据库一起使用:使用日志传送,您可以自动将“主服务器”实例上“主数据库”内的事务日志备份发送到单独“辅助服务器”实例上的一个或多个“辅

Sql语句里面调用变量

sql语句里面调用变量的话有两种情况,一种是字符类型,一种是整型.浮点型之类的数字 db1.Execute("insert DataInformation values('" + user + "','" + list2[j].PlaceID + "'," + list2[j].VELO + "," + list2[j].F + "," + list2[j].SS + "," + lis