mysql中循环截取用户信息,插入到目标表中
来源:互联网 发布:phpcms域名绑定目录 编辑:程序博客网 时间:2024/05/19 12:39
操作环境:有表game_list,字段:uid,score1,score2,seat_id,last_update;
传入参数为i_player_detail ,传入的值为多个用户的id、之前分数、之后分数、座位号,每个用户的数据用分号(;)隔开;
操作目的:将各个用户对应的属性插入到目标表对应的字段中,last_update为数据更新日期;
传入参数i_player_detail ,里面存放多个用户的信息,每个用户的一组数据用分号隔开,每个用户的信息多个,比如
“用户id,score,desk,seat;
用户id,score,desk,seat;……”
-- 使用存储过程
delimiter
use `log_pdk`
BEGIN
DROP TABLE IF EXISTS `temp_list`;
--创建临时表,将截取的数据先插入到临时表
CREATE TEMPORARY TABLE `temp_list`(
`uid` INT(10) UNSIGNED NOT NULL,
`score1` INT(10) UNSIGNED NOT NULL,
`score2` INT(10) UNSIGNED NOT NULL,
`seat_id` TINYINT(3) UNSIGNED NOT NULL
);
-- declare str varchar(500);-- 用来拼接sql动态语句
declare m_detail varchar(500);
declare m_num tinyint;
-- 当传入的用户信息字符串中含有分号';',进行截取
set m_num = position(';' in str) -- 不存在分号的时候,返回0
while m_num >= 1 do
begin
set @str = 'insert into temp_list values (' + substring(m_detail,1,m_num-1)+')' -- 截取第一个用户的信息(第一个分号前面的字符),插入到临时表
prepare statement1 from @str;
execute statement1;
deallocate prepare statement1;
set m_detail = substring(m_detail,m_num+1); -- 定义除去第一个用户和分号那部分的字符串
set set m_num = position(';' in str);
end while;
-- 从临时表抽出所有字段,添加时间字段,插入到表game_list
INSERT INTO `game_list`(`uid`,`score1`,`score2`,`seat_id`, `last_update`)
SELECT `uid`, `score1`, `score2`, `seat_id`, current_date()
FROM `temp_list`;
end
delimiter ;
传入参数为i_player_detail ,传入的值为多个用户的id、之前分数、之后分数、座位号,每个用户的数据用分号(;)隔开;
操作目的:将各个用户对应的属性插入到目标表对应的字段中,last_update为数据更新日期;
传入参数i_player_detail ,里面存放多个用户的信息,每个用户的一组数据用分号隔开,每个用户的信息多个,比如
“用户id,score,desk,seat;
用户id,score,desk,seat;……”
-- 使用存储过程
delimiter
use `log_pdk`
drop procedure if exists `game_c`
create procedure `game_c` (in i_player_detail varchar(500))
SQL SECURITY INVOKERBEGIN
DROP TABLE IF EXISTS `temp_list`;
--创建临时表,将截取的数据先插入到临时表
CREATE TEMPORARY TABLE `temp_list`(
`uid` INT(10) UNSIGNED NOT NULL,
`score1` INT(10) UNSIGNED NOT NULL,
`score2` INT(10) UNSIGNED NOT NULL,
`seat_id` TINYINT(3) UNSIGNED NOT NULL
);
-- declare str varchar(500);-- 用来拼接sql动态语句
declare m_detail varchar(500);
declare m_num tinyint;
-- 当传入的用户信息字符串中含有分号';',进行截取
set m_num = position(';' in str) -- 不存在分号的时候,返回0
while m_num >= 1 do
begin
set @str = 'insert into temp_list values (' + substring(m_detail,1,m_num-1)+')' -- 截取第一个用户的信息(第一个分号前面的字符),插入到临时表
prepare statement1 from @str;
execute statement1;
deallocate prepare statement1;
set m_detail = substring(m_detail,m_num+1); -- 定义除去第一个用户和分号那部分的字符串
set set m_num = position(';' in str);
end while;
-- 从临时表抽出所有字段,添加时间字段,插入到表game_list
INSERT INTO `game_list`(`uid`,`score1`,`score2`,`seat_id`, `last_update`)
SELECT `uid`, `score1`, `score2`, `seat_id`, current_date()
FROM `temp_list`;
end
delimiter ;
0 0
- mysql中循环截取用户信息,插入到目标表中
- mysql中 将传入的多个用户信息,插入到目标表中(方法二)
- Mysql向表中循环插入数据
- mysql数据库中循环插入
- Mysql循环游标并作为其中一个参数插入到另一个表中
- 将文件按照分隔符截取数据,截取的数据,根据要求插入到不同的表中
- Mysql复制一条记录插入到当前表中
- 插入到MySql数据库中乱码问题
- 利用Mybatis插入数据到MySQL中
- MySQL中截取字符串
- MYSQL中创建存储过程实现向表中循环插入数据
- 一次性循环插入 5000条 记录到sqlserver 数据中
- java注册用户信息保存到txt中。
- 循环向表中插入记录
- sql 语句 循环插入100万条数据到某个表中
- 循环读取数据库表数据,并且将结果集插入到sql文本中
- Mysql中插入数据并返回id插入到下一张表。
- drupal 中 插入和更行一个用户信息(user_save)
- IAR 显示编译信息
- HDU 4916 树形dp
- Problems occurred when invoking code from plug-in: "org.eclipse.core.resources"
- 配置linux java 环境
- 设计模式之建造者模式
- mysql中循环截取用户信息,插入到目标表中
- JSP里ContentType ,charset和pageEncoding的理解与区别
- iptables的详细介绍及配置方法
- memcached 常见问题 翻译
- hdoj.2093 考试排名 20140806
- 转载:需求入门: 需求工程=需求开发+需求管理
- SQL SERVER中判断某个字段是否包含大写字母
- GridView中如何取的当前选中行的所有值
- 性能测试工具大全