mysql sql-syntax-prepared-statements 变量做表名&& 字符函数

本文介绍了一个MySQL存储过程示例,该过程用于同步不同数据表间的数据,并展示了如何使用MySQL中的字符串函数进行数据处理。此外,还详细解释了部分字符串函数的用法。

  参考语法 http://dev.mysql.com/doc/refman/5.7/en/sql-syntax-prepared-statements.html

sql 片段 记录下

DELIMITER $$

USE `portal_group`$$

DROP PROCEDURE IF EXISTS `proc_sync_data`$$

CREATE DEFINER=`root`@`%` PROCEDURE `proc_sync_data`(
    )
    SQL SECURITY INVOKER

BEGIN
    DECLARE cur2_tag CURSOR FOR SELECT id ,entity_name,data_from,data_to FROM sync_table WHERE data_from = 'group';
	DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done_cursor = 1 ; 
	
    OPEN cur2_tag;  
	SET done_cursor = 0;
	FETCH cur2_tag INTO var_id,var_entity_name,var_data_from,var_data_to;
	WHILE (done_cursor  = 0) DO
		BEGIN   
		
			IF (fc_sync_data(var_entity,var_data_from_db)='1') THEN
				SET @execSql = CONCAT('select count(*) into @records  from ',var_data_from_db_table,';'); -- 变量 做 表名
				PREPARE stmt1 FROM @execSql;
				EXECUTE stmt1;
				DEALLOCATE PREPARE stmt1; 
				SET num = @records;  -- 从结果中获取 执行的记录数
				
		                IF (num>0) THEN
							SET @execSql = CONCAT('truncate table ',var_data_to_db_table,';'); -- 变量 做 表名 
							PREPARE stmt1 FROM @execSql;  
							EXECUTE stmt1;
							
							SET @execSql = CONCAT('INSERT INTO ',var_data_to_db_table ,' SELECT * FROM ',var_data_from_db_table,';');
							PREPARE stmt1 FROM @execSql;  
							EXECUTE stmt1;
                        END IF;
			END IF;
		END;
		SET done_cursor = 0 ;		
		FETCH cur2_tag INTO var_id,var_entity_name,var_data_from,var_data_to;
	END WHILE;
    CLOSE cur2_tag;
    END$$

DELIMITER ;

字符函数        http://tool.oschina.net/apidocs/apidoc?api=mysql-5.1-zh    12. 函数和操作符

-- mysql 字符串函数
-- 去空格
SELECT LENGTH(TRIM('    123456    '))
6
-- 索引每个字符时 会用到 大小写 
SELECT ASCII('a')<ASCII('z')
1
SELECT ASCII('Z'); 90
SELECT ASCII('A'); 65

SELECT ASCII('a'); 97
SELECT ASCII('z'); 122
-- 替换函数
SELECT REPLACE('ABCDEFGHC','C','123') 
AB123DEFGH123
-- 截取 
SELECT SUBSTRING('1234567890',5,1)
5
SELECT SUBSTRING('1234567890',-5,1)
6



SET @sql = NULL; SELECT JSON_ARRAYAGG( CONCAT('MAX(CASE WHEN td.person_name = ''', person_name, ''' THEN td.work_time ELSE NULL END) AS ''', person_name, '''') ) INTO @sql FROM ( SELECT DISTINCT t2.person_name FROM task1 t1 INNER JOIN t_ps_person_work_time t2 ON t1.id = t2.task_id WHERE t2.work_day BETWEEN '2025-06-26' AND '2025-07-25' AND t2.status = 0 ) t; -- 更精确地移除JSON数组格式 SET @sql = TRIM(BOTH '[""]' FROM @sql); SET @sql = REPLACE(@sql, '","', '", "'); -- 可选,如果需要处理中间部分 -- 或者更简单的方式(如果只有两个元素): SET @sql = REPLACE(REPLACE(@sql, '"', ''), ',', ', '); SET @sql = REPLACE(@sql, '[', ''); SET @sql = REPLACE(@sql, ']', ''); WITH task_data AS ( -- 获取任务和人员工时数据 SELECT t3.task_num , t3.project_name , (SELECT dict_label FROM `js_sys_dict_data` WHERE dict_type = 'sys_project_type' AND dict_value = t3.project_type) project_type, t1.duty_person person_name, ROUND(SUM(t2.work_time), 1) work_time, t2.work_day workDay FROM project t3 INNER JOIN task1 t1 ON t3.id = t1.project_id INNER JOIN ( SELECT person_name, task_id, work_time, DATE_FORMAT(work_day, '%Y-%m') work_day FROM t_ps_person_work_time WHERE work_day BETWEEN '2025-06-26' AND '2025-07-25' AND `status` = 0 ORDER BY work_day ) t2 ON t1.id = t2.task_id WHERE t3.status = 0 AND t1.status = 0 GROUP BY t3.id,t1.person_code ORDER BY t3.task_num ) -- 动态透视查询 SET @sql = CONCAT('SELECT td.task_num AS "任务书号", td.project_name AS "项目称", td.project_type AS "项目类型", ROUND(SUM(td.work_time), 1) AS "项目工时", ', @sql, ' FROM task_data td GROUP BY td.task_num ORDER BY td.task_num'); -- 现在,@sql中存储了动态生成的SQL字符-- 使用预处理语句执行 PREPARE stmt FROM @sql; EXECUTE stmt; DEALLOCATE PREPARE stmt; 我这样修改,> 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'SET @sql = CONCAT('SELECT td.task_num AS "任务书号", td.project_name A' at line 29出现这个错误
最新发布
08-09
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值