积分获取和消费的存储过程
1.GM_JF客户账户积分表 2.GM_JF_DETAIL客户账户积分消费记录 3.GM_JF_ACTION_RULES积分动作规则表 4.GM_JF_GOODS_RULES积分商品规则表 无 -- ===============测试=======================================================/*declare @StatusCode int = 1;exec
1.GM_JF客户账户积分表2. GM_JF_DETAIL客户账户积分消费记录
3. GM_JF_ACTION _RULES积分动作规则表
4.GM_JF_GOODS _RULES积分商品规则表
-- ===============测试======================================================= /* declare @StatusCode int = 1; exec sp_GM_JF_AddScore 'admin','AN_JF_001_001',1,5,0,'',@StatusCode output print @StatusCode */ -- =========================================================================== /* * 判断是否重复获取积分(首次完善个人资料,首次修改密码等等不能重复获取积分) * 判断是根据 从GM_JF_DETAIL(详情表)查询周期内的数据条数与GM_JF_ACTION_RULES(动作规则表)内的周期重复次数对比 * 如果大于等于周期重复次数,则为重复获取积分 * 接下来 * 1.详情表的数据入库 * 2.判断总积分表是否存在对应客户的总积分 没有则插入一条新的,有 则读取其数据,并更新 * */ ALTER PROCEDURE [dbo].[sp_GM_JF_AddScore] @ACCOUNT_ID varchar(30), @JF_CategoryNumber varchar(15), @CARD_NUM int, @HQ_JF_AMOUNT int, @State varchar(16), @USE_DESC varchar(400), @StatusCode int output -- 状态码: 0:失败 1:成功 2: 不能重复获取 AS BEGIN -- SET NOCOUNT ON added to prevent extra result sets from -- interfering with SELECT statements. SET NOCOUNT ON; declare @repetitionsCycle float=0, --周期(天) @repetitionsCycle_second int=0,--周期(秒) @repetitionsFrequency int=0, --一个周期内允许最大次数 @realFrequency int=0, --实际周期 @USE_DATE datetime = GETDATE(); --是否重复获取积分 select top(1) @repetitionsCycle=RepetitionsCycle,@repetitionsFrequency=RepetitionsFrequency from GM_JF_ACTION_RULES where AN_CategoryNumber=@JF_CategoryNumber; if(@repetitionsCycle<1) BEGIN set @repetitionsCycle_second = (@repetitionsCycle-1)*24*60*60; select @realFrequency=COUNT(1) from GM_JF_DETAIL where ACCOUNT_ID=@ACCOUNT_ID and JF_CategoryNumber=@JF_CategoryNumber and USE_DATE <= @USE_DATE and USE_DATE >= CONVERT(varchar(19),DATEADD(SECOND,-@repetitionsCycle_second,@USE_DATE),120) END ELSE BEGIN select @realFrequency=COUNT(1) from GM_JF_DETAIL where ACCOUNT_ID=@ACCOUNT_ID and JF_CategoryNumber=@JF_CategoryNumber and USE_DATE <= @USE_DATE and USE_DATE >= CONVERT(varchar(10),DATEADD(DAY,-(@repetitionsCycle-1),@USE_DATE),120) END if(@realFrequency>=@repetitionsFrequency) --实际周期大于周期次数 begin set @StatusCode = 2; return 2; end declare @count int = 0; --数据条数 declare @temp_table table --表变量 ( ACCOUNT_ID varchar(30), JF_AMOUNT decimal(16,2), TTL_JF_AMOUNT decimal(16,2), Last_Update_Time datetime, [Version] int ); begin tran; --插入详情 insert into GM_JF_DETAIL (ACCOUNT_ID,JF_CategoryNumber,CARD_NUM,HQ_JF_AMOUNT,[State],USE_DESC) values (@ACCOUNT_ID,@JF_CategoryNumber,@CARD_NUM,@HQ_JF_AMOUNT,@State,@USE_DESC) --填充表变量 insert into @temp_table select ACCOUNT_ID,JF_AMOUNT,TTL_JF_AMOUNT,Last_Update_Time,[Version] from GM_JF where ACCOUNT_ID=@ACCOUNT_ID select @count = count(1) from @temp_table; --判断并更新总积分(0:添加 其他:修改) IF(@count=0) begin insert into GM_JF(ACCOUNT_ID,JF_AMOUNT,TTL_JF_AMOUNT) values (@ACCOUNT_ID,@HQ_JF_AMOUNT,@HQ_JF_AMOUNT) end else begin declare @JF_AMOUNT int, --总积分 @TTL_JF_AMOUNT int, --可用积分 @Version int; --版本号 select @JF_AMOUNT=JF_AMOUNT,@TTL_JF_AMOUNT=TTL_JF_AMOUNT,@Version=[Version] from @temp_table where ACCOUNT_ID=@ACCOUNT_ID; update GM_JF set JF_AMOUNT=(@JF_AMOUNT+@HQ_JF_AMOUNT),TTL_JF_AMOUNT=(@TTL_JF_AMOUNT+@HQ_JF_AMOUNT),Last_Update_Time=GETDATE(),[Version]=(@Version+1) where ACCOUNT_ID=@ACCOUNT_ID end Commit tran; set @StatusCode = 1; IF(@@ERROR<>0) BEGIN set @StatusCode = 0; ROLLBACK tran; END END
-- ===============测试======================================================= /* declare @StatusCode int = 1; exec sp_GM_JF_CutScore 'admin','GS_JF_0004',2,1,'',@StatusCode output print @StatusCode*/ -- =============================华丽的分割线=================================== SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO ALTER proc [dbo].[sp_GM_JF_CutScore] @ACCOUNT_ID varchar(30), --兑换ID 如admin @GS_CategoryNumber varchar(12), --兑换商品类型 @CARD_NUM int, --兑换数量 --@HQ_JF_AMOUNT int, --兑换的积分总值 每个类型对应积分量*兑换数量 @State varchar(16),--兑换状态 @USE_DESC varchar(400), --备注 --输出参数 @StatusCode int output -- 状态码: 0:失败 1:成功 2: 不能重复获取 as begin SET NOCOUNT ON;--不返回计数(表示受 Transact-SQL 语句影响的行数) declare --判断处理 自定义变量 @score int , --要兑换商品类型的积分值 @scoreSum int, --要兑换商品类型的积分总值 @JF_AMOUNT int, --可用积分 @Version int; --版本号 select @score=GS_SCORE from GM_JF_GOOD_RULES where GS_CategoryNumber=@GS_CategoryNumber --'GS_JF_0003' if(@CARD_NUM>0) begin set @scoreSum=@score*@CARD_NUM*(-1) end select @JF_AMOUNT=JF_AMOUNT,@Version=[Version] from GM_JF where ACCOUNT_ID=@ACCOUNT_ID; if(@JF_AMOUNT>@scoreSum*(-1)) --判断可用余额是否大于 兑换所需要的积分 begin begin tran; --插入详情 GM_JF_DETAIL insert into GM_JF_DETAIL (ACCOUNT_ID,JF_CategoryNumber,CARD_NUM,HQ_JF_AMOUNT,[State],USE_DESC) values (@ACCOUNT_ID,@GS_CategoryNumber,@CARD_NUM,@scoreSum,@State,@USE_DESC) --修改总表字段 可用余额 版本号 GM_JF update GM_JF set JF_AMOUNT= (@JF_AMOUNT+@scoreSum) ,Last_Update_Time=GETDATE(), [Version]=(@Version+1) where ACCOUNT_ID=@ACCOUNT_ID set @StatusCode = 1; Commit tran; end else begin set @StatusCode = 2; --可用积分小于要兑换物品的积分总值 兑换失败 end IF(@@ERROR<>0) BEGIN set @StatusCode = 2; ROLLBACK tran; end END

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이 웹사이트는 3월 7일 화웨이의 데이터 스토리지 제품 라인 사장인 Zhou Yuefeng 박사가 최근 MWC2024 컨퍼런스에 참석하여 웜 데이터(WarmData)와 콜드 데이터(ColdData)용으로 설계된 차세대 OceanStorArctic 자전 스토리지 솔루션을 구체적으로 시연했다고 보도했습니다. Huawei의 데이터 스토리지 제품 라인 사장 Zhou Yuefeng은 일련의 혁신적인 솔루션을 출시했습니다. 이미지 출처: 이 사이트에 첨부된 Huawei의 공식 보도 자료는 다음과 같습니다. 이 솔루션의 가격은 자기 테이프보다 20% 저렴하며, 전력 소비는 하드 디스크보다 90% 낮습니다. 해외 기술 매체인 blockandfiles에 따르면, Huawei 대변인은 자기전기 저장 솔루션에 대한 정보도 공개했습니다. Huawei의 자기전자 디스크(MED)는 자기 저장 매체의 주요 혁신입니다. 1세대 ME

Google OTP는 사용자 계정의 보안을 보호하기 위해 사용되는 도구로, 그 핵심은 동적 인증 코드를 생성하는 데 사용되는 중요한 정보입니다. Google OTP의 키를 잊어버렸고 보안 코드를 통해서만 확인할 수 있는 경우, 이 웹사이트의 편집자가 Google 보안 코드를 얻을 수 있는 위치에 대한 자세한 소개를 제공할 것입니다. 더 많은 정보를 알고 계시다면 아래 내용을 계속 읽어주세요! 먼저 전화 설정을 열고 설정 페이지로 들어갑니다. 페이지를 아래로 스크롤하여 Google을 찾으세요. Google 페이지로 이동하여 Google 계정을 클릭하세요. 계정 페이지에 들어가서 인증 코드 아래에 있는 보기를 클릭하세요. 비밀번호를 입력하거나 지문을 사용하여 신원을 확인하세요. Google 보안 코드를 받고 보안 코드를 사용하여 Google 신원을 확인하세요.

QQ Music은 다양한 유형의 음악이 포함된 재생 소프트웨어입니다. 여기에서 듣고 싶은 모든 유형의 음악을 검색할 수 있습니다. 모든 음악의 음질은 매우 좋으며 다양한 음질 옵션이 있습니다. 그럼 QQ 뮤직에서 포인트를 모으는 방법을 아시나요? QQ 뮤직에서 포인트를 모으는 방법에 대한 자세한 튜토리얼: 1. 먼저 [QQ 뮤직] 앱 소프트웨어를 열고 하단 기능 표시줄에서 [내] 기능 버튼을 클릭하세요. 2. 그런 다음 [활동 센터] 기능 버튼을 클릭하세요. 3. 이후 [포인트 받기] 버튼을 클릭하시면 포인트를 받으실 수 있습니다. 소프트웨어 소개: 1. 고품질 음악 재생 2. 앨범 사진 및 전체 화면 가사 표시 3. QQ에 로그인하여 컴퓨터의 QQ Music에서 좋아하는 노래를 동기화합니다.

Git은 빠르고 안정적이며 적응력이 뛰어난 분산 버전 제어 시스템입니다. 분산된 비선형 워크플로를 지원하도록 설계되어 모든 규모의 소프트웨어 개발 팀에 이상적입니다. 각 Git 작업 디렉터리는 모든 변경 사항에 대한 전체 기록을 보유하고 네트워크 액세스나 중앙 서버 없이도 버전을 추적할 수 있는 독립적인 저장소입니다. GitHub는 분산 개정 제어의 모든 기능을 제공하는 클라우드에 호스팅되는 Git 저장소입니다. GitHub는 클라우드에서 호스팅되는 Git 저장소입니다. CLI 도구인 Git과 달리 GitHub에는 웹 기반 그래픽 사용자 인터페이스가 있습니다. 이는 다른 개발자와 협력하고 스크립트 변경 사항을 추적하는 버전 제어에 사용됩니다.

국내 휴대폰의 일반적인 작동은 매우 유사하지만 일부 세부 사항에는 여전히 약간의 차이가 있습니다. 예를 들어 휴대폰 모델 및 제조업체에 따라 듀얼 SIM 설치 방법이 다를 수 있습니다. 신형 휴대폰인 Erzhenwo 12Pro도 듀얼심 듀얼 대기를 지원하는데, 이 휴대폰에 듀얼심을 어떻게 설치해야 할까요? Realme 12Pro에 듀얼 SIM을 설치하는 방법은 무엇입니까? 설치하기 전에 휴대폰을 끄는 것을 잊지 마십시오. 1단계: SIM 카드 트레이 찾기: 휴대폰의 SIM 카드 트레이를 찾습니다. 일반적으로 Realme 12 Pro에서는 SIM 카드 트레이가 휴대폰 측면이나 상단에 있습니다. 2단계: 첫 번째 SIM 카드를 삽입합니다. 전용 SIM 카드 핀이나 작은 물체를 사용하여 SIM 카드 트레이의 슬롯에 삽입합니다. 그런 다음 첫 번째 SIM 카드를 조심스럽게 삽입합니다.

Cryptocurrency 거래의 리더로서 Gate.io는 광범위한 거래 쌍, 파생 상품 및 금융 서비스를 제공합니다. 웹 사이트 참깨 오픈 도어 게이트의 중국어 버전은 중국 사용자에게 편리하며 Gate.io와 동일한 기능을 제공하지만 중국인의 습관에 더 적합합니다. 사용자는 지정된 웹 사이트를 통해 Gate.io Exchange 또는 Sesame Open Gate 공식 웹 사이트에 액세스 할 수 있습니다.

많은 플레이어들이 가짜 미래 크리스탈 코인을 얻는 방법을 알고 싶어합니다. 실제로는 선물 패키지 구매, 작업 완료, 상품 생산, 토지 개발 등 네 가지 방법이 있습니다. 플레이어는 필요에 따라 크리스탈 코인을 얻는 다양한 방법을 선택할 수 있습니다. 구체적인 내용은 다음과 같습니다. 일어나서 가짜 미래 크리스탈 코인을 얻는 방법에 대한 이 가이드를 살펴보세요. 가짜 미래 가이드: 가짜 미래 크리스탈 코인 획득 방법 1. 선물 패키지 쇼핑몰을 구매하시면 크리스탈 코인 선물 패키지를 구매하실 수 있습니다. 2. 작업을 완료하고 기본 작업과 부가 작업을 완료하여 획득합니다. 3. 집에서 상품을 생산하여 크리스탈 코인을 획득하세요. 4. 개발지는 토지를 개발하여 획득할 수도 있지만 보상은 일회성입니다.

1. WeChat에 로그인한 후 아래 옵션을 입력하세요: [나] 2. [설정]을 선택한 후 [계정 및 보안]을 찾아 엽니다. 3. 그런 다음 새 인터페이스 하단에서 [WeChat 보안 센터] 옵션을 찾아 엽니다. 4. 새 페이지 진입 후 첫 번째 항목인 [계정 및 비밀번호 찾기]를 선택하세요. 5. [WeChat 계정 비밀번호 찾기 요청]을 직접 사용하여 새 인터페이스로 들어갑니다. 6. 항소 시작을 선택하세요! 이 전화기가 로그인한 모든 WeChat 계정이 표시됩니다.
