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 ;
[@more@]來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7425608/viewspace-1004695/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL5儲存過程使用(轉)MySql儲存過程
- 在Java中實現回撥過程 (轉)Java
- 使用rownum及replace實現行轉列
- 使用儲存過程實現分頁列印 (轉)儲存過程
- Kettle實現行轉列
- sql實現行轉列SQL
- 分隔字串實現列轉行字串
- [Shell] awk 實現列轉行例子
- oracle行轉列、列轉行、連續日期數字實現方式及mybatis下實現方式OracleMyBatis
- Oracle 11g使用UNPIVOT函式實現“列轉行”Oracle函式
- 使用ADO執行儲存過程 (轉)儲存過程
- 使用Command執行儲存過程 (轉)儲存過程
- ADO中sqlserver儲存過程使用 (轉)SQLServer儲存過程
- 通過佇列實現棧OR通過棧實現佇列佇列
- promise實現過程Promise
- iptables實現埠轉發的過程(修改版)(轉)
- 老生常談SQL2005語句實現行轉列,列轉行SQL
- List,DataTable實現行轉列的通用方案
- decode實現行轉列的查詢
- android中foreground水波實現過程分析Android
- ERP專案實施過程中的致命過失(轉)
- 寫了一個MySQL的行轉列的儲存過程薦MySql儲存過程
- oracle儲存過程中的陣列Oracle儲存過程陣列
- KVC、KVO實現過程
- HIVE實現wordcount過程Hive
- 使用NumPy演示實現神經網路過程神經網路
- 使用Oracle 11g函式Pivot實現資料聚合行轉列Oracle函式
- PHP 協程實現過程詳解PHP
- oracle中多列轉行Oracle
- Directx遊戲中嵌入IE瀏覽器實現過程遊戲瀏覽器
- java中listFiles(Filefilter filter)檔案過濾器的實現過程JavaFilter過濾器
- 在C++中實現變長陣列 (轉)C++陣列
- oracle中通過decode實現行變列的二維表統計展示Oracle
- 使用PyTorch演示實現神經網路過程PyTorch神經網路
- PHP中陣列賦值效能及過程PHP陣列賦值
- ORACLE 陣列在過程中的應用Oracle陣列
- 詳細分析棧和佇列的資料結構的實現過程(Java 實現)佇列資料結構Java
- 執行緒安全佇列(使用互斥鎖進行實現)執行緒佇列