實用的銀行轉(zhuǎn)賬存儲過程和流水號生成存儲過程
更新時間:2015年09月28日 11:23:15 作者:只喝牛奶的殺手
本篇文章給大家分享銀行轉(zhuǎn)賬存儲過程和流水號生成存儲過程,感興趣的朋友一起看看吧
銀行轉(zhuǎn)賬存儲過程
USE [BankInfor] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO ALTER PROCEDURE [dbo].[Transfer](@inAccount int,@outAccount int,@amount float) as declare @totalDeposit float; begin select @totalDeposit=total from Account where AccountNum=@outAccount; if @totalDeposit is null begin rollback; print'轉(zhuǎn)出賬戶不存在或賬戶中沒有存款' return; end if @totalDeposit<@amount begin rollback; print'余額不足,不能操作' return; end update Account set total=total-@amount where AccountNum=@outAccount; update Account set total=total+@amount where AccountNum=@inAccount; print'轉(zhuǎn)賬成功!' commit; end;
流水號生成存儲過程
if exists(select 1 from sysobjects where id=OBJECT_ID('GetSerialNo') and xtype='p')
drop proc GetSerialNo
go
Create procedure [dbo].[GetSerialNo]
(
@sCode varchar(50)
)
as
begin
Declare @sValue varchar(16),@dToday datetime,@sQZ varchar(50) --這個代表前綴
Begin Tran
Begin Try
-- 鎖定該條記錄,好多人用lock去鎖,起始這里只要執(zhí)行一句update就可以了
--在同一個事物中,執(zhí)行了update語句之后就會啟動鎖
Update SerialNo set sValue=sValue where sCode=@sCode
Select @sValue = sValue From SerialNo where sCode=@sCode
Select @sQZ = sQZ From SerialNo where sCode=@sCode
-- 因子表中沒有記錄,插入初始值
If @sValue is null
Begin
Select @sValue = convert(bigint, convert(varchar(6), getdate(), 12) + '000001')
Update SerialNo set sValue=@sValue where sCode=@sCode
end else
Begin --因子表中沒有記錄
Select @dToday = substring(@sValue,1,6)
--如果日期相等,則加1
If @dToday = convert(varchar(6), getdate(), 12)
Select @sValue = convert(varchar(16), (convert(bigint, @sValue) + 1))
else --如果日期不相等,則先賦值日期,流水號從1開始
Select @sValue = convert(bigint, convert(varchar(6), getdate(), 12) +'000001')
Update SerialNo set sValue =@sValue where sCode=@sCode
End
Select result = @sQZ+@sValue
Commit Tran
End Try
Begin Catch
Rollback Tran
Select result = 'Error'
End Catch
end
select*from SerialNo
select convert(varchar(6), getdate(), 12)+'000001'
您可能感興趣的文章:
- Android 高仿微信轉(zhuǎn)賬金錢輸入框規(guī)則
- python 實現(xiàn)網(wǎng)上商城,轉(zhuǎn)賬,存取款等功能的信用卡系統(tǒng)
- Python實現(xiàn)信用卡系統(tǒng)(支持購物、轉(zhuǎn)賬、存取錢)
- Python3連接MySQL(pymysql)模擬轉(zhuǎn)賬實現(xiàn)代碼
- 基于Python實現(xiàn)一個簡單的銀行轉(zhuǎn)賬操作
- PHP+Mysql基于事務(wù)處理實現(xiàn)轉(zhuǎn)賬功能的方法
- php利用事務(wù)處理轉(zhuǎn)賬問題
- php+Mysqli利用事務(wù)處理轉(zhuǎn)賬問題實例
- php+mysqli事務(wù)控制實現(xiàn)銀行轉(zhuǎn)賬實例
- 轉(zhuǎn)賬支票、現(xiàn)金支票日期大寫對照表(數(shù)字大寫)
- 微信開發(fā)--企業(yè)轉(zhuǎn)賬到用戶
相關(guān)文章
分頁存儲過程(用存儲過程實現(xiàn)數(shù)據(jù)庫的分頁代碼)
用存儲過程實現(xiàn)數(shù)據(jù)庫的分頁代碼,加快頁面執(zhí)行速度。具體的大家可以測試下。2010-06-06
SQL?Server?Agent?服務(wù)啟動后又停止問題
這篇文章主要介紹了SQL?Server?Agent?服務(wù)啟動后又停止問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04
Linq to SQL 插入數(shù)據(jù)時的一個問題
今天用LinqtoSql插入數(shù)據(jù),總是插入錯誤,說某個主鍵字段不能為空,我檢查了半天感覺主鍵字段沒有賦空值啊,實在是郁悶。 要插入數(shù)據(jù)的表結(jié)構(gòu)是2009-08-08
SQL?Server?查詢設(shè)置??LIKE/DISTINCT/HAVING/排序詳解
本文介紹了在SQLServer中使用LIKE、DISTINCT、HAVING等條件語句進(jìn)行復(fù)雜查詢的方法,包括模糊查詢、去重查詢、分組過濾以及排序等技巧,感興趣的朋友跟隨小編一起看看吧2025-01-01

