mysql 存储过程入门练习——循环创建相同结构的表
背景描述:有很应用中会有多张同结构的表,如果单纯的一个创建或是拷贝、粘贴+更改;也可以完成,表多了总是很痛苦,看了网上的资料,自己动手写了一个练习,呵呵跑通了滴;
目前是学会了使用,但部分为何这样用还不是特别懂,先上跑通的例子再说;
PART1:如何循环创建相同结构的表
mysql> use procduretest
Database changed
mysql> show tables;
-> //;
+------------------------+
| Tables_in_procduretest |
+------------------------+
| cf_file_1 |
| cf_file_2 |
| cf_file_3 |
| cf_file_4 |
| cf_file_5 |
| test_file |
+------------------------+
6 rows in set (0.00 sec)
mysql> delimiter //
mysql> create procedure test1()
-> begin
-> declare aa varchar(256);
-> declare bb varchar(256);
-> declare i int default 1;
-> declare count int default 5;
-> while i<=5 do
-> set aa=CONCAT('cf_file22_',i);
-> set @tfile= CONCAT(' create table ',aa ,' like
-> prepare stmt from @tfile;
-> execute stmt;
-> set i=i+1;
-> end while;
->
-> while i<=5 do
-> set bb=CONCAT('cf_folder_',i);
-> set @tfolder= CONCAT(' create table ',aa ,' li
-> prepare stmt from @tfolder;
-> execute stmt;
-> set i=i+1;
-> end while;
-> end
-> //
Query OK, 0 rows affected (0.00 sec)
mysql> call test1()//;
Query OK, 0 rows affected (0.20 sec)
mysql> show tables;
-> //
+------------------------+
| Tables_in_procduretest |
+------------------------+
| cf_file22_1 |
| cf_file22_2 |
| cf_file22_3 |
| cf_file22_4 |
| cf_file22_5 |
| cf_file2_1 |
| cf_file_1 |
| cf_file_2 |
| cf_file_3 |
| cf_file_4 |
| cf_file_5 |
| test_file |
+------------------------+
12 rows in set (0.00 sec)
mysql>
PART2:为何要这么用呢?
1、为何要将全sql作为变量?
答:
用变量做表名,如果简单的用set或者declare语句定义变量,然后直接作为sql的表名是不行的,mysql会把变量名当作表名。在其他的sql数据库中也是如此,mssql的解决方法是将整条sql语句作为变量,其中穿插变量作为表名,
2、如何在存储过程中执行sql语句:
SET @update_stmt='' /*在单引号中间填入要执行的sql语句*/
PREPARE stmt FROM @update_stmt;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
PREPARE是mysql的预处理语句,基本语法如下:
MySQL prepare语法:
PREPARE statement_name FROM preparable_SQL_statement; /*定义*/
EXECUTE statement_name [USING @var_name [, @var_name] ...]; /*执行预处理语句*/
{DEALLOCATE | DROP} PREPARE statement_name /*删除定义*/ ;
PREPARE语句用于预备一个语句,并指定名称statement_name,以后引用该语句。语句名称对大小写不敏感。
preparable_SQL_statement可以是一个文字字符串,也可以是一个包含了语句文本的用户变量。
该文本必须表现为一个单一的SQL语句,而不是多个语句。在这语句里,‘?’字符可以被用于标识参数,当执行时,以指示数据值绑定到查询后。‘?’字符不应加引号,即使你想要把它们与字符串值结合在一起。参数标记只能用于数据值应该出现的地方,而不是SQL关键字,标识符,等等。
如果预语句已经存在,则在新的预语句被定义前,它会被隐含地删掉。
举个PREPARE直接跟sql语句的例子:
mysql> prepare md5sum from 'select md5(?) AS md5sum';
Query OK, 0 rows affected (0.00 sec)
Statement prepared
mysql> set @a=111;
Query OK, 0 rows affected (0.00 sec)
mysql> set @b=222;
Query OK, 0 rows affected (0.00 sec)
mysql> execute md5sum using @a;
3、为何prepare中用到的sql语句必须是用户变量呢?
如果将以上存储过程中的@tfile改为aa则会出错? 学习中,暂时无解;
附:mysql变量详解 http://hi.baidu.com/%CA%E6%B7%F4%BC%D1%B2%C5%CA%C7%CD%F5%B5%C0/blog/item/65b93f359efbe9afd1a2d3f5.html
分享到:
相关推荐
在这个“MySQL存储过程入门到精通”资料中,你将深入理解存储过程的原理、创建、调用以及优化方法。 一、存储过程的基本概念 存储过程是由一系列SQL语句组成的程序,存储在数据库服务器上,可以被多次调用执行,...
### MySQL存储过程入门学习 #### 一、存储过程概述 **存储过程**(Stored Procedure)是一种在数据库中存储的预先编写并编译好的SQL程序或函数集合。存储过程的主要优势在于可以提高应用程序的性能和响应速度,同时...
完整版 MySQL8.0从入门到精通 MySQL数据库教程 第21章 精通MySQL存储引擎(共31页).ppt 完整版 MySQL8.0从入门到精通 MySQL数据库教程 第22章 PHP操作MySQL数据库(共16页).ppt 完整版 MySQL8.0从入门到精通 MySQL...
MySQL 5.0 存储过程编程入门是数据库管理领域中的一个重要话题,它涉及到数据库的高级功能,使得数据库系统能够执行复杂的逻辑操作,提高数据处理的效率和安全性。存储过程是一组预先编译的SQL语句,可以在需要时被...
本PDF教程全面覆盖了从入门到精通的MySQL存储过程知识,旨在帮助读者深入理解并熟练掌握这一技能。 一、存储过程的基本概念 存储过程是由一系列SQL语句组成的程序,存储在数据库服务器中,可以被多次调用,减少了...
MySQL是世界上最流行的关系型数据库管理系统之一,其强大的功能和灵活性主要得益于它支持多种存储引擎。在MySQL课程中,深入理解存储引擎是至关重要的,因为不同的存储引擎有着不同的特性和适用场景,这直接影响到...
这份“MySQL5.7从入门到精通”的资源旨在为初学者和有经验的开发者提供一个全面的学习指南,通过高清带书签的PDF文档,使得学习过程更加高效和便捷。 一、MySQL基础 MySQL的基础部分通常包括数据库的概念、安装与...
存储过程 in参数 的使用 IN参数只用来向过程传递信息,为默认值。 -- 存储过程中 in 参数的 使用 DELIMITER ;; CREATE PROCEDURE name_in(IN `time` VARCHAR(50)) BEGIN SELECT NOW() ,`time`; END ;; CALL name_in...
MySQL是世界上最流行的关系型数据库管理系统之一,而存储过程和函数是其强大功能的重要组成部分。本章节将深入探讨这两个概念,以及如何在MySQL中创建、调用、查看、修改和删除它们。 1. **创建存储过程和函数** -...
在MySQL 入门教程中,我们能够看到很多关于如何创建储存过程 和如何利用 IN 和 OUT 参数调用存储过程的示例。这些示例都很简单,能够很好的帮助你理解 MySQL 中创建带参数存储过程的语法。这些示例已在 MySQL 5.5 中...
《MySQL从入门到精通》这本书是为初学者和有一定基础的数据库管理员设计的,它全面覆盖了MySQL的基础知识...希望你在阅读《MySQL从入门到精通》的过程中,不仅能掌握数据库的基础知识,还能培养出解决实际问题的能力。
MySQL 5.7是世界上最流行的开源关系型数据库管理系统之一,被广泛应用于Web应用程序、电子商务、数据分析...《MySQL5.7从入门到精通》这本书应该会提供详尽的教程和实例,帮助你在学习过程中更好地理解和掌握这些内容。
第二阶段---MySQL存储过程实例教程.doc 第二阶段---MYSQL存储过程技术ppt 第二阶段---MySQL导入导出数据库文件.doc 第二阶段---Mysgl数据类型(字段)介绍.doc 第二阶段---MySQL样例数据库、操作库操作表实例教程.doc ...
MySQL存储过程详解 MySQL存储过程是MySQL中常用的数据库对象,它是一组为了完成特定功能的预编译的SQL语句集合。存储过程是一种命名的程序块,在第一次使用经过编译之后,再次调用时不用再编译,因此执行效率较高。...
在实践中,了解如何在各种数据库系统(如MySQL、SQL Server、Oracle等)中创建和调用存储过程也是重要的。每个系统可能有不同的语法和特性,但基本原理是一致的。 通过阅读"存储过程从入门到熟练"这份文档,你将有...
使用python语言,Django框架,实现调用mysql存储过程。包括通过Navicat工具在mysql数据库中创建存储过程的方法,django配置文件,路由规则,前端页面的使用,通过类实现get和post请示。 适合人群: 初学或刚入门的...
7. **存储过程和函数**:编写和调用存储过程和用户定义函数,了解它们在提高代码复用性和安全性方面的价值。 8. **事务处理**:理解事务的开始、提交、回滚以及隔离级别,学习如何在MySQL中实现事务控制。 9. **...
以下是对"mysql5.5从入门到精通.pdf"文档中可能涵盖的一些关键知识点的详细解释: 1. **安装与配置**: - MySQL的安装过程,包括Windows、Linux和macOS等不同操作系统的安装方法。 - 配置my.cnf文件,调整数据库...
### MySQL入门+进阶资源合集 #### 一、MySQL基础知识与入门 ##### 1.1 MySQL基础概念 - **数据库(Database)**:是用于存储数据的逻辑容器,它能够高效地管理和组织数据。 - **表(Table)**:是数据库中用来存储...
2. "01-MySQL数据库入门 教学设计.doc":这部分可能详细介绍了MySQL的背景,安装过程,以及基本的数据库概念。 3. "02-数据库和表的基本操作 教学设计.doc":这里将介绍如何创建数据库,定义表结构,以及插入、查询...