根据提供的文件信息,我们可以分析并总结出以下关于存储过程 `CM_Carrier_Business_Logic` 的关键知识点: ### 存储过程概述 该存储过程名为 `CM_Carrier_Business_Logic`,其主要功能是处理与运营商 (`Carrier`) 相关的数据迁移逻辑。此过程接受一个参数 `@cm_id`,类型为 `varchar(50)`,用于标识特定的运营商或业务实体。 ### 事务处理 - **事务开始**:通过 `begin tran` 命令启动一个新的事务。这确保了所有数据库操作都在一个原子性的环境中执行。 - **错误处理**:如果在事务执行过程中遇到任何错误(由 `@@ERROR <> 0` 检测),则会触发错误处理流程,包括: - 抛出一个自定义错误消息:`RAISERROR('数据写入cm_carrier_history表出错,数据搬移终止!',18,1)` - 回滚事务:`rollback transaction` - 终止存储过程执行:`RETURN` - **事务提交**:如果事务中的所有操作都成功完成,则使用 `commit transaction` 命令提交事务。 ### 数据处理逻辑 1. **参数解析**:首先解析输入参数 `@cm_id`,从中提取出运营商名称 `@omc_name`。 ```sql declare @omc_name varchar(50); set @omc_name = substring(@cm_id, 1, charindex('.', @cm_id) - 1); ``` 2. **数据更新**:接下来,该过程查找具有相同前缀 `@omc_name` 的最大 `cm_id` 值,并将其更新为传入的 `@cm_id`。 ```sql declare @cm_id_carrier varchar(50); select @cm_id_carrier = isnull(max(cm_id), '') from CM_Carrier_New where cm_id like @omc_name + '%'; if @cm_id <> '' Update CM_Carrier_New set cm_id = @cm_id where cm_id = @cm_id_carrier; ``` 这一步是后续数据迁移的关键准备步骤之一。 3. **数据迁移**:将符合条件的数据从 `cm_carrier_info` 表迁移到 `cm_carrier_history` 表。 ```sql INSERT INTO cm_carrier_history select * from cm_carrier_info where omc_name = @omc_name; ``` ### 其他重要信息 - **注释**:代码中包含了一些注释,提供了修改记录等信息,这对于理解代码变更历史非常有帮助。 - **SQL 设置**:最后部分包含了关闭 `QUOTED_IDENTIFIER` 和开启 `ANSI_NULLS` 的 SQL 设置语句,这些设置可能会影响 SQL 查询的行为,尤其是在处理字符串和 NULL 值时。 ### 总结 `CM_Carrier_Business_Logic` 存储过程主要用于处理运营商相关的数据迁移任务。它通过一系列的 SQL 命令实现了数据的更新和迁移,同时利用事务来确保数据的一致性和完整性。此外,代码中还包含了错误处理机制,能够有效避免因数据操作异常而导致的问题。这些知识点对于理解该存储过程的功能和实现细节至关重要。
CREATE PROCEDURE CM_Carrier_Business_Logic
@cm_id varchar(50)
AS
begin tran
/*从info中往history搬移数据,首先要判断info中是否有数据,如果有就循环插入到history中*/
declare @omc_name varchar(50)
set @omc_name=substring(@cm_id ,1,charindex('.',@cm_id )-1)
-- Modified by YYS 2006-8-18
declare @cm_id_carrier varchar(50)
select @cm_id_carrier= isnull(max(cm_id),'') from CM_Carrier_New where cm_id like @omc_name +'%'
if @cm_id <> ''
Update CM_Carrier_New set cm_id= @cm_id where cm_id=@cm_id_carrier
-- END YYS
INSERT INTO cm_carrier_history
select * from cm_carrier_info where omc_name = @omc_name
IF @@ERROR <> 0
BEGIN
RAISERROR('数据写入cm_carrier_history表出错,数据搬移终止!',18,1)
rollback transaction
RETURN
END
- 粉丝: 1
- 资源: 4
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助