佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 實用的銀行轉(zhuǎn)賬存儲過程和流水號生成存儲過程

實用的銀行轉(zhuǎn)賬存儲過程和流水號生成存儲過程

熱門標簽:Linux服務器 地方門戶網(wǎng)站 AI電銷 呼叫中心市場需求 百度競價排名 鐵路電話系統(tǒng) 網(wǎng)站排名優(yōu)化 服務外包

銀行轉(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基于事務處理實現(xiàn)轉(zhuǎn)賬功能的方法
  • php利用事務處理轉(zhuǎn)賬問題
  • php+Mysqli利用事務處理轉(zhuǎn)賬問題實例
  • php+mysqli事務控制實現(xiàn)銀行轉(zhuǎn)賬實例
  • 轉(zhuǎn)賬支票、現(xiàn)金支票日期大寫對照表(數(shù)字大寫)
  • 微信開發(fā)--企業(yè)轉(zhuǎn)賬到用戶

標簽:衡水 銅川 蘭州 仙桃 湘潭 湖南 崇左 黃山

巨人網(wǎng)絡通訊聲明:本文標題《實用的銀行轉(zhuǎn)賬存儲過程和流水號生成存儲過程》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    台前县| 类乌齐县| 阳西县| 赫章县| 永平县| 神农架林区| 洛扎县| 辰溪县| 乐平市| 搜索| 安阳县| 庆城县| 翼城县| 宿松县| 怀集县| 青铜峡市| 勃利县| 岳阳市| 云龙县| 汕头市| 新乡市| 呈贡县| 东乡县| 莆田市| 保定市| 陇川县| 巴塘县| 南丹县| 瓦房店市| 舟曲县| 上林县| 鄂尔多斯市| 东台市| 江北区| 上犹县| 香格里拉县| 乐昌市| 越西县| 宜宾市| 尼木县| 德庆县|