mysql5中怎么在使用过程实现行转列

60次阅读
没有评论

共计 1575 个字符,预计需要花费 4 分钟才能阅读完成。

自动写代码机器人,免费开通

本篇内容主要讲解“mysql5 中怎么在使用过程实现行转列”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让丸趣 TV 小编来带大家学习“mysql5 中怎么在使用过程实现行转列”吧!

简单到网上搜了一下,没有发现 mysql 有类似 oracle 的 decode 函数实现行转列,有不少用过程实现动态行转列,试了一下,不适合我用,参考 mysql5 的帮助,写个个过程,记录备忘。其中用到了游标,关于游标的使用文档里给的例子也不错,反正我就只会那么用。。。

DELIMITER $$

DROP PROCEDURE IF EXISTS `hrb_yd`.`proc_hrb_yd_stat`$$

CREATE DEFINER=`root`@`192.168.96.1` PROCEDURE `proc_hrb_yd_stat`(IN $G_id INTEGER(10))
BEGIN
declare v_name VARCHAR(255);
declare  v  INT DEFAULT 0;
declare  v1  INT DEFAULT 0;
declare  v2  INT DEFAULT 0;
declare  v3  INT DEFAULT 0;
declare  v4  INT DEFAULT 0;
declare  v5  INT DEFAULT 0;
declare  v6  INT DEFAULT 0;
declare a int ;
declare b varchar(255);
DECLARE done INT DEFAULT 0;
declare cur1 cursor for select id,name from  hrb_yd_admin  where g_id=$G_id ;
DECLARE CONTINUE HANDLER FOR SQLSTATE 02000 SET done = 1;

select count(id) into v from hrb_yd_admin where g_id=$G_id;
open cur1;
repeat
fetch cur1 into  a,b;
if  not done then
select count(id) into v1 from hrb_yd_visit_table  where  user_id=a  and  visit_way= 实地走访 /* 实地走访次数 */
select count(id) into v2 from hrb_yd_visit_table  where  user_id=a  and visit_way= 电话  ;    /*– 电话拜访方式次数 */
select count(id) into v3 from hrb_yd_visit_table  where  user_id=a  and visit_way= E—mail  ;  /*–emianl 拜访方式次数 */
select count(id) into v4 from hrb_yd_visit_table  where  user_id=a  and visit_way =        /*– 其他拜访方式次数 */
select count(id) into v5 from hrb_yd_visit_table  where  user_id=a  and visit_un_purpose= 是  /*– 推荐成功数 */
select count(id) into v6 from hrb_yd_visit_table  where  user_id=a  and visit_un_purpose= 否 /*– 未推荐成功数 */
select b,v1,v2,v3,v4,v5,v6;
end if;
until done end repeat;
close cur1;

END$$

DELIMITER ;

到此,相信大家对“mysql5 中怎么在使用过程实现行转列”有了更深的了解,不妨来实际操作一番吧!这里是丸趣 TV 网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计1575字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)