--把若干条sql语句封装起来,起个名字,叫做过程,也是没有返回值的函数
--把这个过程存储在数据库中->存储过程
--存储过程的创建过程
create procedure proceduceName()
begin
sql 语句
end$ --查看
show procedure status \G --调用
call procedureName()$ --声明变量
declare age int default 18; --运算
set age:=age+10; --改变边界
delimiter $ --例子
create procedure p1()
begin
declare age int default 18; set age:=age+10;
select age;
end$ --用call p1()$调用时出现 age 28
--创建表
create table test(
id int,
name varchar(30) not null default '',
age int,
content varchar(40)
)engine myisam charset utf8$ --插入数据
insert into test values (1,'zhangsan',13,'学习好'),(2,'lisi',15,'智慧的化身'),(2,'wangwu',14,'不起眼')$
--存储过程存储sql语句
create procedure p2()
begin
select content from test where age=15;
end$ --存储过程是可以编程的
--意味着可以使用变量,表达式,控制结构完成复杂的功能 --if/else语句的使用
if 条件 then
语句;
else if 条件 then
语句;
else
语句;
end if; create procedure p3()
begin
declare age int default 18; if age>=18 then
select '你已经成年了';
else
select '未成年';
end if;
end$ --while 循环
while 条件 do
语句;
end while; --括号里可以声明参数
--参数类型 [in/out/inout] 参数名 参数类型
create procedure p4(agee int)
begin
select name from test where age=agee;
end$ in 表示输入参数 传参
out 表示输出参数 传变量名 向外传值 要设置初始化值
inout 输入参数执行后再输出 传入一个声明过的变量名 create procedure p5(in age int)
begin
select age as '你几岁了';
end$ --out 参数,要在procedure 内部初始化参数
create procedure p6(out result int)
begin
declare i int default 1;
set result:=0;
while i<=100 do
set result:=result+i;
set i:=i+1;
end while;
end$
--调用
call p6(@num)$
select @num$ --inout 参数
create procedure p7(inout age int)
begin
set age:=age+10;
select age as '10年后你几岁了';
end$ set @age=10$
call p7(@age)$
select @age$ --case语句
case 变量名
when 值1 then 操作1;
when 值2 then 操作2;
...
else 操作n;
end case; --repeat 循环
repeat
操作语句
until 条件 end repeat;

MySQL数据库的存储结构的更多相关文章

  1. MySQL数据库InnoDB存储引擎多版本控制(MVCC)实现原理分析

    文/何登成 导读:   来自网易研究院的MySQL内核技术研究人何登成,把MySQL数据库InnoDB存储引擎的多版本控制(简称:MVCC)实现原理,做了深入的研究与详细的文字图表分析,方便大家理解I ...

  2. MySQL数据库InnoDB存储引擎中的锁机制

    MySQL数据库InnoDB存储引擎中的锁机制    http://www.uml.org.cn/sjjm/201205302.asp   00 – 基本概念 当并发事务同时访问一个资源的时候,有可能 ...

  3. MySQL数据库MyISAM存储引擎转为Innodb

    MySQL数据库MyISAM存储引擎转为Innodb  之前公司的数据库存储引擎全部为MyISAM,数据量和访问量都不是很大,所以一直都没什么问题.但是最近出现了MySQL数据表经常被锁的情况,直接导 ...

  4. MySQL数据库Raid存储方案

    作为一名DBA,选择自己的数据存储在什么上面,应该是最基本的事情了.但是很多DBA却容易忽略了这一点,我就是其中一个.之前对raid了解的并不多,本文就记录下学习的raid相关知识. 一.RAID的基 ...

  5. Ubuntu上更改MySQL数据库数据存储目录

    之前写过一篇博客"MySQL更改数据库数据存储目录",当时的测试环境是RHEL和CentOS,谁想最近在Ubuntu下面更改MySQL数据库数据存储目录时遇到了之前未遇到的问题,之 ...

  6. MySQL InnoDB 逻辑存储结构

    MySQL InnoDB 逻辑存储结构 从InnoDB存储引擎的逻辑结构看,所有数据都被逻辑地存放在一个空间内,称为表空间,而表空间由段(sengment).区(extent).页(page)组成.p ...

  7. MySQL数据库InnoDB存储引擎

    MySQL数据库InnoDB存储引擎Log漫游  http://blog.163.com/zihuan_xuan/blog/static/1287942432012366293667/

  8. 查看和改动MySQL数据库表存储引擎

            要做一名合格的程序猿,除了把代码写的美丽外,熟知数据库方面的知识也是不可或缺的.以下总结一下怎样查看和改动MySQL数据库表存储引擎:        1.查看数据库所能支持的存储引擎: ...

  9. MYSQL Innodb逻辑存储结构

    转载于网络 这几天在读<MySQL技术内幕 InnoDB存储引擎>,对 Innodb逻辑存储结构有了些了解,顺便也记录一下: 从InnoDB存储引擎的逻辑存储结构看,所有数据都被逻辑地存放 ...

随机推荐

  1. Nginx反向代理 负载均衡 页面缓存 URL重写及读写分离

    大纲 一.前言 二.环境准备 三.安装与配置Nginx 四.Nginx之反向代理 五.Nginx之负载均衡 六.Nginx之页面缓存 七.Nginx之URL重写 八.Nginx之读写分离 注,操作系统 ...

  2. dll开发中遇到的问题

    刚碰到个问题,我的一个项目中引用了一个dll,这个dll又引用了另一个dll,我把这俩个都放在bin文件夹下,但是会报错,说第二个dll找不到.把它放到系统文件夹system32下就没事了. 但是遇到 ...

  3. HDU 1796How many integers can you find(简单容斥定理)

    How many integers can you find Time Limit: 12000/5000 MS (Java/Others)    Memory Limit: 65536/32768 ...

  4. Webstorm2016激活码[ 转]

    转至:http://blog.csdn.net/tingwode2014_/article/details/51063657 43B4A73YYJ-eyJsaWNlbnNlSWQiOiI0M0I0QT ...

  5. [转]freemarker中的list

    转至:http://zhuyuehua.iteye.com/blog/1975251 freemarker list (长度,遍历,下标,嵌套,排序) 1. freemarker获取list的size ...

  6. 模板引擎doT.js介绍及如何判断对象为空、如何嵌套循环···

    doT.js 灵感来源于搜寻基于 V8 和 Node.js ,强调性能,最快速最简洁的 JavaScript 模板函数 引入 javascript 文件: <script type=" ...

  7. ADO.NET 快速入门(十):过滤数据

    我们有很多方法来过滤数据.一种是在数据库命令级别,利用 where 子句查询过滤数据.另一种是在数据填充到 DataSet 以后过滤数据.本篇讨论后者.   一旦数据填充到 DataSet,你可以使用 ...

  8. Winform-控制边框显示属性

  9. Codeforces Round #334 (Div. 2) D. Moodular Arithmetic 环的个数

    D. Moodular Arithmetic Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/60 ...

  10. Codeforces Gym 100286F Problem F. Fibonacci System 数位DP

    Problem F. Fibonacci SystemTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudg ...