MySQL存储过程实现行转列

把表t_rows中的数据转换为列显示 CREATE TABLE `t_rows` ( `dt_str` varchar(20) NOT NULL, `name` varchar(20) NOT NULL, `age` int(11) NOT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 表t_rows行显示的结果为 mysql SELECT `dt_str`, `name`, `age` FROM

把表t_rows中的数据转换为列显示
CREATE TABLE `t_rows` (
  `dt_str` varchar(20) NOT NULL,
  `name` varchar(20) NOT NULL,
  `age` int(11) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

表t_rows行显示的结果为
mysql> SELECT `dt_str`, `name`, `age` FROM `t_rows`;
+———-+———–+—–+
| dt_str   | name      | age |
+———-+———–+—–+
| 20120610 | name_9881 |  81 |
| 20120609 | name_9882 |  82 |
| 20120608 | name_9883 |  83 |
| 20120607 | name_9884 |  84 |
| 20120606 | name_9885 |  85 |
| 20120605 | name_9886 |  86 |
| 20120604 | name_9887 |  87 |
| 20120603 | name_9888 |  88 |
| 20120602 | name_9889 |  89 |
| 20120601 | name_9890 |  90 |
| 20120531 | name_9891 |  91 |
+———-+———–+—–+

转换为

图片“列显示.jpg”(文字格式有点乱,只好贴图了)的显示方式

dt_str 20120610 20120609 20120608 20120607 20120606 20120605 20120604 20120603 20120602 20120601 20120531
name name_9881 name_9882 name_9883 name_9884 name_9885 name_9886 name_9887 name_9888 name_9889 name_9890 name_9891
age 81 82 83 84 85 86 87 88 89 90 91

存储过程定义:
DELIMITER $$

DROP PROCEDURE IF EXISTS `pr_row_to_col`$$

CREATE DEFINER=`root`@`%` PROCEDURE `pr_row_to_col`()
COMMENT ‘将表t_row中的3列(`dt_str`, `name`, `age`)数据转换为列显示’
proc_start:BEGIN

DECLARE _end INT DEFAULT 0;

— 临时表名
DECLARE _TEMP_TB_NAME VARCHAR(255) DEFAULT ‘t_temp_rows_to_col’;

— 创建存储列数据的表结构sql
DECLARE _sql_create TEXT;
— 每列数据的拼接的字符串,因为此例只查询3列(`dt_str`, `name`, `age`)数据
— 假设每列所有行的拼接字符串不超过TEXT,如果超过可以使用longtext等
DECLARE _res_dt,_res_name,_res_age TEXT;
— 每个数据的长度定义为varchar(255),如果数据最大长度超过255,则改为最大值即可
DECLARE _dt_str,_name,_age VARCHAR(255) DEFAULT ”;
— 分隔符
DECLARE _SPLITER CHAR(1) DEFAULT ‘,’;

— 查询所有行数据的游标
DECLARE _cur CURSOR FOR SELECT `dt_str`, `name`, `age` FROM t_rows;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET _end=1;

— 打开游标
OPEN _cur;

— 初始化
SET _res_dt=”;
SET _res_name=”;
SET _res_age=”;

— drop临时表
SET @exe_str=CONCAT(“DROP TABLE IF EXISTS “,_TEMP_TB_NAME);
PREPARE stmt FROM @exe_str;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

— 创建存储列数据的表结构sql
SET _sql_create=CONCAT(“create table “,_TEMP_TB_NAME,”(“);

SET _sql_create=CONCAT(_sql_create,”col0 VARCHAR(255) NOT NULL,”);
SET @i=1;
rep_start:REPEAT
FETCH  _cur INTO _dt_str, _name, _age;
IF _end=1 THEN
LEAVE rep_start;
END IF;

— 拼接每列数据的字符串
SET _res_dt=CONCAT(_res_dt,”‘”,_dt_str,”‘”,_SPLITER);
SET _res_name=CONCAT(_res_name,”‘”,_name,”‘”,_SPLITER);
SET _res_age=CONCAT(_res_age,”‘”,_age,”‘”,_SPLITER);

— 拼接创建表结构字符串
SET _sql_create=CONCAT(_sql_create,”col”,@i,” VARCHAR(255) NOT NULL,”);

SET @i=@i+1;

UNTIL _end=1 END REPEAT rep_start;

— 截取每个字符串最后的分隔符
SET _res_dt=SUBSTRING(_res_dt,1,(LENGTH(_res_dt)-1));
SET _res_name=SUBSTRING(_res_name,1,(LENGTH(_res_name)-1));
SET _res_age=SUBSTRING(_res_age,1,(LENGTH(_res_age)-1));
SET _sql_create=SUBSTRING(_sql_create,1,(LENGTH(_sql_create)-1));

— 拼接创建表结构字符串
SET _sql_create=CONCAT(_sql_create,”)ENGINE=MEMORY DEFAULT CHARACTER SET utf8″);

— 关闭游标
CLOSE _cur;

— 创建列数据存储使用的临时表
SET @exe_str=_sql_create;
PREPARE stmt FROM @exe_str;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

— 插入列数据,在每列数据前插入了列名
SET @exe_str=CONCAT(“INSERT INTO “,_TEMP_TB_NAME,” VALUES (‘dt_str’,”,_res_dt,”),(‘name’,”,_res_name,”),(‘age’,”,_res_age,”)”);
PREPARE stmt FROM @exe_str;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

— 输出行转列后的数据
SET @exe_str=CONCAT(“SELECT * FROM “,_TEMP_TB_NAME);
PREPARE stmt FROM @exe_str;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

END proc_start$$

DELIMITER ;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1702295.html

(0)
上一篇 2025年2月19日 14:52:17
下一篇 2025年2月19日 14:52:37

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 使用PHP开发web应用程序有哪些优势

    PHP在Web应用程序开发中的优势:1. 开源免费;2. 易于学习;3. 丰富的库和框架;4. 跨平台兼容性;5. 与数据库无缝集成;6. 高效性能;7. 庞大的社区支持;8. 广泛的行业应用。 PHP开发Web应用程序的优势 PHP作为一…

    2025年2月23日
    100
  • php制作地图数据库应该储存哪些属性

    PHP 地图数据库属性包括:几何属性:表示要素形状(geom)。非几何属性(元数据):唯一标识符(id)、名称(name)、描述(description)、类型(type)、其他属性(properties)、标签(tags)、可见性(vis…

    2025年2月23日
    100
  • 在使用php时需要用到哪些软件

    成功使用 PHP 所需软件:文本编辑器或集成开发环境(IDE)Web 服务器PHP 解释器数据库管理系统(DBMS) 使用 PHP 所需软件 PHP (超文本预处理语言) 是一种广泛用于 Web 开发的脚本语言。为了成功使用 PHP,您需要…

    2025年2月23日
    100
  • php程序员需要掌握的技能有哪些

    PHP 程序员必备技能:1. 核心 PHP 语言基础,包括语法、数据类型、控制流和函数;2. 面向对象编程;3. Web 开发:HTML、CSS、JavaScript、HTTP 协议、服务器端编程;4. 数据库:SQL 查询语言、DBMS、…

    2025年2月23日
    100
  • PHP高级工程师具备哪些技能

    PHP 高级工程师必备技能包括:精通 PHP 编程语言,包括其核心概念和语法。掌握流行的 PHP 框架和库。熟练数据库管理,包括关系型和非关系型数据库。擅长性能优化和云计算。具备沟通、团队合作、解决问题和批判性思维等软技能。持续关注职业发展…

    2025年2月23日
    100
  • php如何配置mysql

    为 PHP 配置 MySQL 需要按以下步骤操作:安装 MySQL 扩展。编辑 php.ini 配置文件,启用扩展。创建包含 MySQL 连接信息的凭证文件。在 PHP 脚本中使用 mysqli_connect() 函数连接到 MySQL。…

    2025年2月23日
    100
  • php怎么实现修改数据功能

    PHP 中修改数据库数据的步骤如下:建立数据库连接。准备 SQL UPDATE 语句,指定表、列和新值。执行 SQL UPDATE 语句。检查影响的行数。 PHP 修改数据功能 如何实现 PHP 修改数据功能? PHP 中可以通过使用 SQ…

    2025年2月23日
    100
  • php代码增删改查怎么实现的

    PHP 中 CRUD 操作包括:连接数据库增(插入新记录)删(删除记录)改(更新记录)查(查询记录) PHP 增删改查的实现 PHP 中的增删改查(CRUD)操作是数据库操作的基本功能,用于管理数据库中的数据。以下是实现 CRUD 操作的步…

    2025年2月23日
    100
  • php有多少个内建的函数

    PHP 内置了 8147 个函数,分类包括:字符串函数、数组函数、数学函数、日期时间函数、文件函数、错误处理函数和数据库访问函数。获取内建函数列表可使用 get_defined_functions() 函数。 PHP 内建函数的数量 PHP…

    2025年2月23日
    100
  • 如何配置phpstudy

    通过八个步骤配置 PHPstudy,包括:安装软件、配置 Apache 服务器、选择 PHP 版本、配置 MySQL 数据库、创建 MySQL 用户、配置 PHPMyAdmin、配置其他组件(可选)并完成配置。 如何配置 PHPstudy …

    2025年2月23日
    100

发表回复

登录后才能评论