mysql动态sql 整理多个字段
原始表:

整理后的表:

方案一(动态sql):
BEGIN
#Routine body goes here...
DECLARE v1 int();
DECLARE v2 int();
#DECLARE v3 VARCHAR(); #DECLARE vcompany VARCHAR();
#DECLARE vname VARCHAR(); DECLARE vcol VARCHAR();
DECLARE tmp_sql VARCHAR();
DECLARE vid int(); set v1 = ;
WHILE v1 <= DO
set v2=;
#if v2 <=27 THEN
WHILE v2 <= DO set @v3=CONCAT('l',v2);
set @vcompany='';
set @vname='';
#set @vid=''; SET @l_sql=CONCAT_ws(' ',
'select company_name,',@v3,
'into @vcompany,@vname',
'from for_xun_cha where id =',v1);
SET @sql=@l_sql;
prepare stmt from @sql;
execute stmt; #select company_name,l2 into vcompany,vname from for_xun_cha where id=v2;
if LENGTH(trim(@vname)) > THEN
INSERT into tmp(company,name) VALUES(@vcompany,@vname);
#INSERT into tmp(company,name) VALUES(vcompany,tmp_sql);
end if;
set v2 = v2+;
#end if;
end WHILE;
set v1 = v1 + ;
END WHILE; END
方案二(先合并各列,再用游标处理):
BEGIN
DECLARE Done INT DEFAULT ;
DECLARE n int ; -- 最大列
DECLARE companyName VARCHAR() ;-- 公司名称
DECLARE personNames VARCHAR();-- 员工名称
DECLARE personName VARCHAR(); DECLARE _cur CURSOR FOR select company_name ,CONCAT_WS(",",l2,l3,l4,l5,l6,l7,l8,l9,l10,l11,l12,l13,l14,l15,l16,l17,l18,l19,l20,l21,l22,l23,l24,l25,l26,l27) from for_xun_cha; OPEN _cur;
FETCH _cur INTO companyName,personNames;
REPEAT
IF NOT Done THEN
test: WHILE(n<=) DO
set personName=SUBSTRING_INDEX(SUBSTRING_INDEX(personNames,',',n),',',-);
if ISNULL(personName) || LENGTH(trim(personName))< THEN
LEAVE test;
ELSE
INSERT INTO temp1 VALUES (companyName,personName);
END IF;
set n=n+;
end while;
end IF;
set n = ;
FETCH NEXT FROM _cur INTO companyName,personNames;
UNTIL Done END REPEAT; -- set personName="";
-- set personNames="";
CLOSE _cur;
END
mysql动态sql 整理多个字段的更多相关文章
- MySQL常用SQL整理
MySQL常用SQL整理 一.DDL #创建数据库 CREATE DATABASE IF NOT EXISTS product DEFAULT CHARSET utf8 COLLATE utf8_ge ...
- Mysql动态sql语句,用当前时间做表名
在mysql备份操作中, 我们可能要使用表名和当前时间来做为备份表的名称,但是MySQL在存储过程中不支持使用变量名来做表名或者列名. 例如:有一个表"user",我需要备份一份, ...
- MySQL 动态sql语句运行 用时间做表名
1. 描写叙述 在使用数据的时候,我时候我们须要非常多数据库,并且想用时间来做表名以区分.可是MySQL在存储过程中不支持使用变量名来做表名或者列名. 比方,有一个表我们想以"2015-07 ...
- Mysql中用SQL增加、删除字段,修改字段名、字段类型、注释,调整字段顺序总结
转自:http://www.111cn.net/database/mysql/71648.htm 1.增加一个字段 代码如下 复制代码 //增加一个字段,默认为空 alter table user ...
- Java-Mybatis动态SQL整理
XML映射器 SQL映射文件的几个顶级元素: cache - 该命名空间的缓存配置 cache-ref - 引用其他命名空间的缓存配置 resultMap - 描述如何从数据库结果集中加载对象 sql ...
- DB2和MySQL常用SQL整理
1.Truncate删除表中所有数据 truncate table USER immediate; 说明:Truncate是一个能够快速清空资料表内所有资料的SQL语法.并且能针对具有自动递增值的字段 ...
- MYSQL: sql中某一个字段内容为用逗号分割的字符串转换成多条数据
场景: 表名:testsuer id name 1 小红,小李,李红,小法 要结果值为: 1 小红 1 小李 1 李红 1 小法 MYSQL函数解释 ...
- mysql下sql语句令某字段值等于原值加上一个字符串
MYSQL在一个字段值后面加字符串,如下: member 表名 card 字段名 update member SET card = '00' || card; (postgreSQL 用 || 来连贯 ...
- mysql 用sql 语句去掉某个字段重复值数据的方法
示例代码如下: create table tmp as select min(主键) as col1 from 去重表名 GROUP BY 去重字段; delete from 去重表名 where 主 ...
随机推荐
- jQuery EasyUI教程之datagrid应用
一.利用jQuery EasyUI的DataGrid创建CRUD应用 对网页应用程序来说,正确采集和管理数据通常很有必要,DataGrid的CRUD功能允许我们创建页面来列表显示和编辑数据库记录.本教 ...
- 【转】@JoinColumn 详解
在address中没有特殊的注解. 在Person中对应到数据库里面就有一个指向Address的外键. 我们也可以增加注释指定外键的列的名字,如下:@OneToOne(cascade=CascadeT ...
- 【转】Microsoft .Net Remoting之Marshal、Disconnect与生命周期以及跟踪服务
Marshal.Disconnect与生命周期以及跟踪服务 一.远程对象的激活 在Remoting中有三种激活方式,一般的实现是通过RemotingServices类的静态方法来完成.工作过程事实上是 ...
- qt 窗口控件自动调整大小
/******************************************************************** * qt 窗口控件自动调整大小 * * 在写gui的时候,希 ...
- Netstat命令(windows下)
功能: 一般用于检验本机各端口的网络连接情况. 例子:检查本机3389远程连接端口是否可用 netstat -nao|find "3389" 查看某进程使用的端口号: netst ...
- qlineedit控件获得焦点
出处:http://blog.sina.com.cn/s/blog_640531380100wld9.html qlineedit控件获得焦点 lineEdit->setFocus();
- markdown 转 pdf 方法
(1)Mou: (macosx 系统下的markdown编辑器,转pdf完美,推荐) http://25.io/mou/ (2)Chrome 打印 (打印得很好看,缺点是转好的pdf上的文字有时候不能 ...
- centos6.5的软件安装,用户管理等
1.软件的安装命令: 第一种:以 软件名.rpm 为结尾的二进制文件,这样的文件的安装 rpm -ivh 软件名.rpm i 是 install v 是校验 h 进度 卸载软件 是 rpm -e 软件 ...
- MS17-010 EternalBlue SMB Remote Windows Kernel Pool Corruption 2017-05-18 16:45
wget "https://raw.githubusercontent.com/rapid7/metasploit-framework/6d81ca42087efd6548bfcf92417 ...
- php将汉字转换为拼音和得到词语首字母(二)
<?php class Pinyin{ private $_outEncoding = "GB2312"; public function getPinyin($str,$p ...