`
ohfanfan
  • 浏览: 52494 次
  • 性别: Icon_minigender_1
  • 来自: 厦门
社区版块
存档分类
最新评论

mysql 存储过程入门

 
阅读更多
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 存储过程入门到精通

    在这个“MySQL存储过程入门到精通”资料中,你将深入理解存储过程的原理、创建、调用以及优化方法。 一、存储过程的基本概念 存储过程是由一系列SQL语句组成的程序,存储在数据库服务器上,可以被多次调用执行,...

    MySQL存储过程入门学习

    ### MySQL存储过程入门学习 #### 一、存储过程概述 **存储过程**(Stored Procedure)是一种在数据库中存储的预先编写并编译好的SQL程序或函数集合。存储过程的主要优势在于可以提高应用程序的性能和响应速度,同时...

    完整版 MySQL8.0从入门到精通 MySQL数据库教程 全套PPT课件资源集合 共26个章节 含全部源代码.rar

    完整版 MySQL8.0从入门到精通 MySQL数据库教程 第21章 精通MySQL存储引擎(共31页).ppt 完整版 MySQL8.0从入门到精通 MySQL数据库教程 第22章 PHP操作MySQL数据库(共16页).ppt 完整版 MySQL8.0从入门到精通 MySQL...

    小题大做之MySQL 5.0存储过程编程入门(转)

    MySQL 5.0 存储过程编程入门是数据库管理领域中的一个重要话题,它涉及到数据库的高级功能,使得数据库系统能够执行复杂的逻辑操作,提高数据处理的效率和安全性。存储过程是一组预先编译的SQL语句,可以在需要时被...

    MySQL存储过程pdf

    本PDF教程全面覆盖了从入门到精通的MySQL存储过程知识,旨在帮助读者深入理解并熟练掌握这一技能。 一、存储过程的基本概念 存储过程是由一系列SQL语句组成的程序,存储在数据库服务器中,可以被多次调用,减少了...

    MySQL课程之MySQL存储引擎入门

    MySQL是世界上最流行的关系型数据库管理系统之一,其强大的功能和灵活性主要得益于它支持多种存储引擎。在MySQL课程中,深入理解存储引擎是至关重要的,因为不同的存储引擎有着不同的特性和适用场景,这直接影响到...

    MySQL5.7从入门到精通 带书签 高清

    这份“MySQL5.7从入门到精通”的资源旨在为初学者和有经验的开发者提供一个全面的学习指南,通过高清带书签的PDF文档,使得学习过程更加高效和便捷。 一、MySQL基础 MySQL的基础部分通常包括数据库的概念、安装与...

    详解MySql存储过程参数的入门使用

    存储过程 in参数 的使用 IN参数只用来向过程传递信息,为默认值。 -- 存储过程中 in 参数的 使用 DELIMITER ;; CREATE PROCEDURE name_in(IN `time` VARCHAR(50)) BEGIN SELECT NOW() ,`time`; END ;; CALL name_in...

    完整精品数据库课件 MySQL从入门到精通 第10章 存储过程和函数(共19页).ppt

    MySQL是世界上最流行的关系型数据库管理系统之一,而存储过程和函数是其强大功能的重要组成部分。本章节将深入探讨这两个概念,以及如何在MySQL中创建、调用、查看、修改和删除它们。 1. **创建存储过程和函数** -...

    在MySQL中创建带有IN和OUT参数的存储过程的方法

    在MySQL 入门教程中,我们能够看到很多关于如何创建储存过程 和如何利用 IN 和 OUT 参数调用存储过程的示例。这些示例都很简单,能够很好的帮助你理解 MySQL 中创建带参数存储过程的语法。这些示例已在 MySQL 5.5 中...

    mysql 4从入门到精通

    《MySQL从入门到精通》这本书是为初学者和有一定基础的数据库管理员设计的,它全面覆盖了MySQL的基础知识...希望你在阅读《MySQL从入门到精通》的过程中,不仅能掌握数据库的基础知识,还能培养出解决实际问题的能力。

    mysql 5.7从入门到精通

    MySQL 5.7是世界上最流行的开源关系型数据库管理系统之一,被广泛应用于Web应用程序、电子商务、数据分析...《MySQL5.7从入门到精通》这本书应该会提供详尽的教程和实例,帮助你在学习过程中更好地理解和掌握这些内容。

    MySql零基础入门到精通(资料集)SQL语句+触发器+存储过程+安装卸载+导入导出+性能优化

    第二阶段---MySQL存储过程实例教程.doc 第二阶段---MYSQL存储过程技术ppt 第二阶段---MySQL导入导出数据库文件.doc 第二阶段---Mysgl数据类型(字段)介绍.doc 第二阶段---MySQL样例数据库、操作库操作表实例教程.doc ...

    MySQL从入门到实战学习教程之10存储过程.pptx

    MySQL存储过程详解 MySQL存储过程是MySQL中常用的数据库对象,它是一组为了完成特定功能的预编译的SQL语句集合。存储过程是一种命名的程序块,在第一次使用经过编译之后,再次调用时不用再编译,因此执行效率较高。...

    存储过程从入门到熟练(多个存储过程完整实例及调用方法)

    在实践中,了解如何在各种数据库系统(如MySQL、SQL Server、Oracle等)中创建和调用存储过程也是重要的。每个系统可能有不同的语法和特性,但基本原理是一致的。 通过阅读"存储过程从入门到熟练"这份文档,你将有...

    mysql存储过程的使用

    使用python语言,Django框架,实现调用mysql存储过程。包括通过Navicat工具在mysql数据库中创建存储过程的方法,django配置文件,路由规则,前端页面的使用,通过类实现get和post请示。 适合人群: 初学或刚入门的...

    MySQL5.7从入门到精通》

    7. **存储过程和函数**:编写和调用存储过程和用户定义函数,了解它们在提高代码复用性和安全性方面的价值。 8. **事务处理**:理解事务的开始、提交、回滚以及隔离级别,学习如何在MySQL中实现事务控制。 9. **...

    mysql5.5从入门到精通.pdf

    以下是对"mysql5.5从入门到精通.pdf"文档中可能涵盖的一些关键知识点的详细解释: 1. **安装与配置**: - MySQL的安装过程,包括Windows、Linux和macOS等不同操作系统的安装方法。 - 配置my.cnf文件,调整数据库...

    MySQL入门+进阶资源合集.pdf

    ### MySQL入门+进阶资源合集 #### 一、MySQL基础知识与入门 ##### 1.1 MySQL基础概念 - **数据库(Database)**:是用于存储数据的逻辑容器,它能够高效地管理和组织数据。 - **表(Table)**:是数据库中用来存储...

    MySQL数据库入门.rar

    2. "01-MySQL数据库入门 教学设计.doc":这部分可能详细介绍了MySQL的背景,安装过程,以及基本的数据库概念。 3. "02-数据库和表的基本操作 教学设计.doc":这里将介绍如何创建数据库,定义表结构,以及插入、查询...

Global site tag (gtag.js) - Google Analytics