JSnack使用心得(二)

本文介绍了一种在存储过程中实现字符串拆分(split)的方法。通过循环调用SPLIT_SUB_STR函数来逐个处理输入字符串中的元素,并将这些元素写入数据库表中。示例展示了如何将角色权限字符串拆分为单独的权限项。


如何在存储过程中进行split操作

原理:循环调用SPLIT_SUB_STR

示例代码如下:

sp_SaveRole

参数IN `myrolename` varchar(64),IN `mypermission` varchar(512)


BEGIN


  declare _rolename varchar(64);
  declare _roleid int default 0;
  declare _permission varchar(512);
  declare _splititem varchar(64);


  set _rolename = myrolename;
  set _permission = mypermission;
  set _roleid = 0;


  insert into sys_roles(name) values(_rolename);
   select roleid into _roleid from sys_roles order by roleid desc limit 1;
 
 REPEAT
    
    CALL SPLIT_SUB_STR(_permission, ',', _splititem);
    insert into sys_rolepermissions (roleid, permissionid) values(_roleid, _splititem);
UNTIL _permission = ''
END REPEAT;
  
END


这里根据参数分解mypermission,split写入表中


输入为'员工','1,2'


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

灰暗角落里的琴

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值