ALTER PROCEDURE [dbo].[CM_HANGHOA_Ins] @p_HH_CODE varchar(50) = NULL, @p_HH_NAME nvarchar(200) = NULL, @p_HH_TYPE_ID varchar(15) = NULL, @p_DESCRIPTION nvarchar(2000) = NULL, @p_SUP_ID varchar(15) = NULL, @p_PRICE decimal(18) = NULL, @p_UNIT_ID varchar(15) = NULL, @p_NOTES nvarchar(1000) = NULL, @p_RECORD_STATUS varchar(1) = NULL, @p_MAKER_ID varchar(15) = NULL, @p_CREATE_DT VARCHAR(20) = NULL, @p_AUTH_STATUS varchar(50) = NULL, @p_CHECKER_ID varchar(12) = NULL, @p_APPROVE_DT VARCHAR(20) = NULL, @p_GD_ID varchar(15) = NULL, @p_HHGROUP_GROUP_ID_TTCT varchar(15) = NULL, @p_HHGROUP_GROUP_ID_CDT varchar(15) = NULL, @p_DVCM_ID varchar(15) = NULL, @p_IS_DVCM varchar(1) =NULL AS DECLARE @l_HH_ID VARCHAR(15) BEGIN TRANSACTION --KIEM TRA MA LA DUY NHAT IF EXISTS (SELECT * FROM CM_HANGHOA WHERE HH_CODE = @p_HH_CODE AND RECORD_STATUS ='1') BEGIN ROLLBACK TRANSACTION SELECT -1 as Result, '' HH_ID, N'Mã hàng hóa: '+ @p_HH_CODE +N' đã tồn tại trong hệ thống' ErrorDesc RETURN -1 END IF(@p_MAKER_ID NOT IN ('vanpt2','phuongvn','tuyenlt')) BEGIN ROLLBACK TRANSACTION SELECT -1 as Result, '' HH_ID, N'Bạn không nằm trong danh sách những user được phép thêm mới hàng hóa. Vui lòng liên hệ bộ phận Mua Hàng - Phòng Hành Chính Hội Sở' ErrorDesc RETURN -1 END IF (@p_HH_CODE IS NULL OR @p_HH_CODE = '') BEGIN DECLARE @Max_ID int; DECLARE @s VARCHAR(200) = (SELECT MAX(HH_CODE) FROM CM_HANGHOA WHERE HH_TYPE_ID = @p_HH_TYPE_ID); WITH a AS (SELECT n=0, i=-1, j=0 UNION ALL SELECT n+1, j, CHARINDEX('-', @s, j+1) FROM a WHERE j > i), b AS (SELECT n, SUBSTRING(@s, i+1, IIF(j>0, j, LEN(@s)+1)-i-1) s FROM a WHERE i >= 0) SELECT @Max_ID=(s+1) FROM b WHERE n = 3 DECLARE @HH_CODE varchar(15) = (select HH_TYPE_CODE from CM_HANGHOA_TYPE where HH_TYPE_ID = @p_HH_TYPE_ID) select @p_HH_CODE = (@HH_CODE+'-' + right('00000'+convert(varchar(20),ISNULL(@Max_ID,0)),6)) END IF(@p_HH_CODE IS NULL OR @p_HH_CODE ='') BEGIN ROLLBACK TRANSACTION SELECT -1 as Result, '' HH_ID, N'Mã hàng hóa chưa tự động phát sinh. Vui lòng nhập mã hàng hóa' ErrorDesc RETURN -1 END IF(@p_HHGROUP_GROUP_ID_TTCT IS NULL OR @p_HHGROUP_GROUP_ID_TTCT ='') BEGIN ROLLBACK TRANSACTION SELECT -1 as Result, '' HH_ID, N'Thông tin nhóm hạn mức phê duyệt chủ trương không được phép để trống. Đây là thông tin quan trọng cho quy trình phê duyệt chủ trương' ErrorDesc RETURN -1 END IF(@p_HHGROUP_GROUP_ID_CDT IS NULL OR @p_HHGROUP_GROUP_ID_CDT ='') BEGIN ROLLBACK TRANSACTION SELECT -1 as Result, '' HH_ID, N'Thông tin nhóm hạn mức phê duyệt hạn mức chỉ định thầu không được phép để trống. Đây là thông tin quan trọng cho quy trình phê duyệt chủ trương -mua sắm chỉ định thầu' ErrorDesc RETURN -1 END ------------------BAODNQ 24/10/2022 : K CHO CHỌN DVCM LÀ KHỐI----------------- IF EXISTS(SELECT * FROM CM_DVDM WHERE DVDM_ID = @p_DVCM_ID AND IS_KHOI = 1) BEGIN ROLLBACK TRANSACTION SELECT -1 as Result, '' HH_ID, N'Không thể chọn đơn vị chuyên môn là Khối để đi với hàng hóa. Vui lòng chọn đơn vị chuyên môn khác' ErrorDesc RETURN -1 END -------------------END BAODNQ------------------------ -----------------BAODNQ 12/1/2023 : HOT FIX TẠM THỜI NẾU MAKER_ID = vanpt2 THÌ UPDATE MAKER_ID = admin---------- IF(@p_MAKER_ID = 'vanpt2') BEGIN SET @p_MAKER_ID = 'admin' END EXEC SYS_CodeMasters_Gen 'CM_HANGHOA', @l_HH_ID out IF @l_HH_ID='' OR @l_HH_ID IS NULL GOTO ABORT SET @p_AUTH_STATUS = 'A' IF EXISTS (SELECT * FROM TL_MENU WHERE MENU_NAME_EL = N'hanghoa' and ISAPPROVE_FUNC = 1) BEGIN SET @p_AUTH_STATUS = 'U' END INSERT INTO CM_HANGHOA([HH_ID],[HH_CODE],[HH_NAME],[HH_TYPE_ID],[DESCRIPTION],[SUP_ID],[PRICE],[UNIT_ID],[NOTES],[RECORD_STATUS],[MAKER_ID],[CREATE_DT],[AUTH_STATUS],[CHECKER_ID],[APPROVE_DT],[GD_ID],[IS_DVCM]) VALUES(@l_HH_ID ,@p_HH_CODE ,@p_HH_NAME ,@p_HH_TYPE_ID ,@p_DESCRIPTION ,@p_SUP_ID ,@p_PRICE ,@p_UNIT_ID ,@p_NOTES ,@p_RECORD_STATUS ,@p_MAKER_ID ,CONVERT(DATETIME, @p_CREATE_DT, 103) ,@p_AUTH_STATUS ,@p_CHECKER_ID ,CONVERT(DATETIME, @p_APPROVE_DT, 103), @p_GD_ID,@p_IS_DVCM) DELETE SYS_HH_GROUP_LIMIT WHERE HH_ID = @l_HH_ID INSERT INTO SYS_HH_GROUP_LIMIT(HH_ID, GROUP_LIMIT_ID, TYPE_LIMIT) VALUES (@l_HH_ID, @p_HHGROUP_GROUP_ID_TTCT, 'TTCT') INSERT INTO SYS_HH_GROUP_LIMIT(HH_ID, GROUP_LIMIT_ID, TYPE_LIMIT) VALUES (@l_HH_ID, @p_HHGROUP_GROUP_ID_CDT, 'CDT') DELETE CM_HANGHOA_DVCM WHERE HH_ID = @l_HH_ID AND DVCM_ID = @p_DVCM_ID INSERT INTO CM_HANGHOA_DVCM(HH_ID, DVCM_ID) VALUES (@l_HH_ID, @p_DVCM_ID) IF @@Error <> 0 GOTO ABORT COMMIT TRANSACTION SELECT 0 as Result, @l_HH_ID HH_ID,@p_HH_CODE as HH_CODE,@l_HH_ID as Id,@p_HH_CODE as Ids, '' ErrorDesc RETURN 0 ABORT: BEGIN ROLLBACK TRANSACTION SELECT -1 as Result, '' HH_ID, N'Thêm thất bại' ErrorDesc RETURN -1 End