實用的銀行轉賬存儲過程和流水號生成存儲過程
更新時間:2015年09月28日 11:23:15 作者:只喝牛奶的殺手
本篇文章給大家分享銀行轉賬存儲過程和流水號生成存儲過程,感興趣的朋友一起看看吧
銀行轉賬存儲過程
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'轉出賬戶不存在或賬戶中沒有存款' 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'轉賬成功!' 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 高仿微信轉賬金錢輸入框規(guī)則
- python 實現(xiàn)網上商城,轉賬,存取款等功能的信用卡系統(tǒng)
- Python實現(xiàn)信用卡系統(tǒng)(支持購物、轉賬、存取錢)
- Python3連接MySQL(pymysql)模擬轉賬實現(xiàn)代碼
- 基于Python實現(xiàn)一個簡單的銀行轉賬操作
- PHP+Mysql基于事務處理實現(xiàn)轉賬功能的方法
- php利用事務處理轉賬問題
- php+Mysqli利用事務處理轉賬問題實例
- php+mysqli事務控制實現(xiàn)銀行轉賬實例
- 轉賬支票、現(xiàn)金支票日期大寫對照表(數(shù)字大寫)
- 微信開發(fā)--企業(yè)轉賬到用戶
相關文章
數(shù)據(jù)庫SQL中having和where的用法區(qū)別
這篇文章主要介紹了數(shù)據(jù)庫SQL中having和where的用法區(qū)別的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-11-11SQL中的游標、異常處理、存儲函數(shù)及總結(最新推薦)
游標(cursor)是用來存儲查詢結果集的數(shù)據(jù)類型,在存儲過程和函數(shù)中可以使用游標對結果集進行循環(huán)的處理,這篇文章主要介紹了SQL中的游標、異常處理、存儲函數(shù)及總結,需要的朋友可以參考下2023-02-02SQLSERVER?出現(xiàn)死鎖查找方法和解決辦法(推薦)
這篇文章主要介紹了SQLSERVER?出現(xiàn)死鎖查找方法和解決辦法(推薦),文中講解了查詢死鎖語句,殺死死鎖的解決方法,需要的朋友可以參考下2024-02-02