execute immediate 改mysql
时间: 2023-05-03 07:00:58 浏览: 391
这是一个Python中的字符串变量,其中包含一个十六进制编码,想要使用它需要先将其解码。该字符串看起来像是一条修改MySQL表结构的SQL语句,使用execute immediate可以直接执行该语句。
相关问题
begin for r in (select a.TABLE_NAME,a.COLUMN_NAME,a.DATA_TYPE,a.DATA_LENGTH,b.comments from user_tab_columns a INNER JOIN user_col_comments b on a.table_name=b.table_name and a.column_name=b.column_name where data_type='NUMBER' and data_precision='20' and data_scale='2' and a.TABLE_NAME not IN('M_TOP_TEN_CREDIT_CUST','A_G15_ALL_RELATION_TXN','A_G15_TOP_TEN_CREDIT_CUST','V_GLF_CUST_INFO_NOREPEAT','A_INT_FEE','A_NONCREDIT_TXN_ALL') AND B.comments NOT IN ('12个月同类交易笔数','关联方期初持有本行的股数','关联方期末持有本行的股数','期初持有银行股数(股)','期末持有银行股数(股)指标值')) LOOP --增加临时新字段 execute immediate 'ALTER table "'|| r.TABLE_NAME ||'" ADD "'|| r.COLUMN_NAME ||'1" NUMBER(18,2)'; --复制内容 execute immediate 'Update "'|| r.TABLE_NAME ||'" Set "'|| r.COLUMN_NAME ||'1" = "'|| r.COLUMN_NAME ||'"'; --清空原有字段值 execute immediate 'Update "'|| r.TABLE_NAME ||'" Set "'|| r.COLUMN_NAME ||'" = null'; --修改原有的字段长度 execute immediate 'ALTER table "'|| r.TABLE_NAME ||'" MODIFY "'|| r.COLUMN_NAME ||'" NUMBER(18,2)'; --把值迁回原有字段 execute immediate 'Update "'|| r.TABLE_NAME ||'" Set "'|| r.COLUMN_NAME ||'" = "'|| r.COLUMN_NAME ||'1"'; --删除新增字段 execute immediate 'ALTER table "'|| r.TABLE_NAME ||'" drop column "'|| r.COLUMN_NAME ||'1"'; end loop; end ;改写成MySQL
在 MySQL 中,可以按照以下方式重写该代码:
```
BEGIN
DECLARE done INT DEFAULT 0;
DECLARE tableName VARCHAR(100);
DECLARE columnName VARCHAR(100);
DECLARE dataType VARCHAR(100);
DECLARE dataLength INT;
DECLARE comments VARCHAR(100);
DECLARE sql_stmt VARCHAR(1000);
DECLARE cur CURSOR FOR SELECT TABLE_NAME, COLUMN_NAME, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH, COLUMN_COMMENT FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA = 'your_database_name' AND DATA_TYPE = 'decimal' AND NUMERIC_PRECISION = 20 AND NUMERIC_SCALE = 2 AND TABLE_NAME NOT IN ('M_TOP_TEN_CREDIT_CUST','A_G15_ALL_RELATION_TXN','A_G15_TOP_TEN_CREDIT_CUST','V_GLF_CUST_INFO_NOREPEAT','A_INT_FEE','A_NONCREDIT_TXN_ALL') AND COLUMN_COMMENT NOT IN ('12个月同类交易笔数','关联方期初持有本行的股数','关联方期末持有本行的股数','期初持有银行股数(股)','期末持有银行股数(股)指标值');
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
OPEN cur;
read_loop: LOOP
FETCH cur INTO tableName, columnName, dataType, dataLength, comments;
IF done THEN
LEAVE read_loop;
END IF;
SET sql_stmt = CONCAT('ALTER TABLE `', tableName, '` MODIFY COLUMN `', columnName, '` DECIMAL(18,2)');
PREPARE stmt FROM sql_stmt;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
SET sql_stmt = CONCAT('ALTER TABLE `', tableName, '` ADD COLUMN `', columnName, '1` DECIMAL(18,2)');
PREPARE stmt FROM sql_stmt;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
SET sql_stmt = CONCAT('UPDATE `', tableName, '` SET `', columnName, '1` = `', columnName, '`');
PREPARE stmt FROM sql_stmt;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
SET sql_stmt = CONCAT('UPDATE `', tableName, '` SET `', columnName, '` = NULL');
PREPARE stmt FROM sql_stmt;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
SET sql_stmt = CONCAT('UPDATE `', tableName, '` SET `', columnName, '` = `', columnName, '1`');
PREPARE stmt FROM sql_stmt;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
SET sql_stmt = CONCAT('ALTER TABLE `', tableName, '` DROP COLUMN `', columnName, '1`');
PREPARE stmt FROM sql_stmt;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
END LOOP;
CLOSE cur;
END;
```
需要注意的是,MySQL 中 DECIMAL 数据类型的定义方式与 Oracle 中的 NUMBER 数据类型不同。在 MySQL 中,DECIMAL(18,2) 表示该字段的总长度为 18 位,小数位为 2 位。此外,MySQL 中需要使用反引号来引用表名和字段名。
MySQL批量查询语句
MySQL支持批量查询语句,通常用于一次执行多个相关的查询,以提高效率,减少网络往返次数。这种批量查询常用于存储过程、预编译语句或者用户自定义函数。以下是一些常见的批量查询形式:
1. **使用EXECUTE PROCEDURE/STMT()**: 这是在存储过程中执行多条SQL语句。例如:
```sql
DECLARE @stmts VARCHAR(255);
SET @stmts = CONCAT('INSERT INTO table VALUES (', VALUES_LIST(?, ?, ...), ');',
'UPDATE table SET column = ?', VALUES_LIST(?, ...), ';');
EXECUTE IMMEDIATE @stmts USING VALUES (value1, value2, ..., valueN);
```
2. **使用PREPARE和EXECUTE**: 预先准备一个带占位符的SQL语句,然后多次绑定参数执行。如:
```sql
PREPARE stmt FROM 'INSERT INTO table VALUES (?, ?), ( ?, ?)';
SET @i = 1;
WHILE @i <= N DO
CALL bind_param(stmt, i, value_i);
EXECUTE stmt;
SET @i = @i + 1;
END WHILE;
DEALLOCATE PREPARE stmt;
```
3. **使用UNION ALL**: 当涉及到相似的数据结构时,可以合并多个SELECT语句并使用`UNION ALL`。但这并不是真正的批量查询,只是查询结果的合并。
4. **使用动态SQL**:根据条件生成动态的SQL字符串,但这种方法需要注意SQL注入风险。
批量查询的好处在于减少了网络请求次数和服务器解析时间,但是要注意控制好查询的数量和复杂度,避免导致内存溢出或者锁争用等问题。
阅读全文
相关推荐
















