本文参考1:MYSQL对sql的拓展

本文参考2:MySQL编程基础

本文参考3:MySql数据库编程

(侵删)

一.变量的定义

1.用户变量

set @变量名=表达式;

说明:无提前进行定义,直接用赋值语句赋值,就算是定义了,也可以用select赋值语句赋值

2.系统变量

set @@系统变量名(=值)

3.局部变量声明

declare 变量名 数据类型;

说明:必须指明类型,生命周期:定义局部变量的小范围

二.语句

1.赋值语句

(1)set语句

set  变量 = 表达式

(2)select语句

select  表达式 into 变量;//不产生结果集
select 变量 := 表达式;//产生结果集

(3)同时给多个变量赋值,用逗号隔开。

set 变量1 = 表达式1,变量2 = 表达式2,……

说明:当你想显示结果集的时候,直接用select+变量名即可在输出区显示出结果集

eg:

2.重置命令结束标记

delimiter 结束标记;

说明:由于MySQL客户机的默认结束标记和语句的结束标记相同,都是分号,所以在写语句块的时候,为避免语句块被;拆开,应在语句块前重设客户机结束标志,然后在语句块结束后改为原样

DELIMITER $$    //将客户机结束标记改为$$
BEGIN
要执行的功能代码;
END;
$$
DELIMITER ; //将客户机结束标记改回;

3.begin-end语句块:将功能封装到存储过程、函数、触发器、事件等存储程序内部。

4.条件控制语句

(1)if语句

IF 条件 THEN 语句块;
ELSE IF 条件 THEN 语句块;
……
ELSE 语句块;
END IF;

(2)case语句

CASE 表达式
WHEN 值1 THEN 语句块;
WHEN 值2 THEN 语句块;
……
ELSE 语句块;
END CASE;

5.循环语句

(1)while-do语句

WHILE 条件表达式 DO  //继续循环的条件
循环体;
END WHILE;

(2)repete-until语句

REPEAT
循环体;
UNTIL 条件表达式 //跳出循环的条件
END REPEAT;

(3)loop语句

循环标签:LOOP
循环体;
IF 条件表达式 THEN LEAVE 循环标签; //跳出循环的条件
END IF;
END LOOP;

三、存储过程

1.介绍

存储过程是一种命名PL/SQL块,是为了完成某种特定功能的PL/SQL的语句集。存储过程有名字,编译后长期存储在数据库中,通过存储过程的名字和参数调用它,存储过程可以多次反复执行,效率高。

2.创建存储过程

(1)声明分割符

一定注意上述分割符的使用,MySQL默认以“;”为分割符,如果没有进行分割符的声明,那么编译器会把存储过程当成SQL语句进行处理,则存储过程的编译过程会报错,所以事先要用delimiter关键字声明当前段的分割符。用完了以后要记得还原

(2)格式

样例:

delimiter &&
create procedure demo(inout p_in int)
begin
select p_in;
set p_in=2;
select p_in;
end;
&&
delimiter ;

说明:在命令行的执行过程中,select可以显示变量选择变量,set就是对变量进行赋值,可以在最左边的栏中见到新建立的存储过程,并且可以直接调用执行

set @p_in=1;
call demo(@p_in);

结果显示:

(3)变量的定义declare

declare l_int int unsigned default 40000;
declare l_num number(8,2) default 9.95;
declare l_date date default '1999-12-31';
declare l_datetime datetime default '1999-12-31 23:59:59';
declare l_varchar varchar(255) default 'This will not be padded';

(4)用户变量

select 'hello world' into @x;
select @x;

显示结果:

(5)样例

-- 从1到100的数字之和
delimiter *
create procedure kaka(out count int)
begin
declare v1 int(11) default 1;
declare v2 int(11) default 0;
while v1 < 100 do
set v2 = v2 + v1;
set v1 = v1 + 1;
end while;
set count = v2;
end;
call kaka(@count);
select @count;
*
delimiter

 四、函数

1.自定义函数及其调用

DELIMITER $$
CREATE FUNCTION 函数名(参数1,参数2,…) RETURNS 返回值类型
[函数选项]
BEGIN
函数体;
RETURN 返回值;
END;
$$
DELIMITER ;

样例:

delimiter &&
create function sum(a int,b int)returns int
begin
declare c int;
set c=a+b;
return c;
end;
&&
delimiter ;

调用:

set @a=2,@b=3;
set @c=`test`.`sum`(@a, @b);
select @c;

输出:

说明:函数的修改用alter,函数的删除用drop

基于Mysql的编程语言(实验六、七)的更多相关文章

  1. MySQL数据库实验六:存储过程建立与调用

    实验六  存储过程建立与调用 一.实验目的 理解存储过程的概念.建立和调用方法. 二.实验环境 三.实验示例 1.定义一个函数,按性别计算所有学生的平均年龄. CREATE FUNCTION aver ...

  2. 2017-2018-1 我爱学Java 第六七周 作业

    团队六七周作业 完善版需求规格说明书 制定团队编码规范 数据库设计 后端架构设计 TODOList 参考资料 完善版需求规格说明书 <需求规格说明书>初稿不足之处: 1.开发工具写错 2. ...

  3. 201871010132-张潇潇-《面向对象程序设计(java)》第六-七周学习总结

    201871010132-张潇潇-<面向对象程序设计(java)>第六-七周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh ...

  4. 我的MYSQL学习心得(六) 函数

    我的MYSQL学习心得(六) 函数 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类 ...

  5. Oracle 实验四-七

    shutdown immediateORA-01097: 无法在事务处理过程中关闭 - 请首先提交或回退 解决:先 "commit" 实验四 SQL Production :: C ...

  6. VMware vSphere服务器虚拟化实验六 vCenter Server 添加储存

                                                                          VMware vSphere服务器虚拟化实验六 vCente ...

  7. 搭建基于MySQL的读写分离工具Amoeba

    搭建基于MySQL的读写分离工具Amoeba: Amoeba工具是实现MySQL数据库读写分离的一个工具,前提是基于MySQL主从复制来实现的: 实验环境(虚拟机): 主机 角色 10.10.10.2 ...

  8. JAVA程序对MYSQL数据库加锁实验

    什么是脏读,不可重复读,幻读 1. 脏读 :脏读就是指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据. 2. 不可重 ...

  9. 基于Mysql数据库亿级数据下的分库分表方案

    移动互联网时代,海量的用户数据每天都在产生,基于用户使用数据的用户行为分析等这样的分析,都需要依靠数据都统计和分析,当数据量小时,问题没有暴露出来,数据库方面的优化显得不太重要,一旦数据量越来越大时, ...

随机推荐

  1. 阿里二面:什么是mmap?

    平时在面试中你肯定会经常碰见的问题就是:RocketMQ为什么快?Kafka为什么快?什么是mmap? 这一类的问题都逃不过的一个点就是零拷贝,虽然还有一些其他的原因,但是今天我们的话题主要就是零拷贝 ...

  2. error: failed to push some refs to 'XXX'

    遇到上述无法提交的问题:都是这种命令git push -u origin master造成的 查看github上的提示: 解决:把之前的命令中的master修改成main就好了

  3. 13、Script file 'E:\Anaconda Distribution\Anaconda\Scripts\pip-script.py' is not present.

    pip-script.py文件缺失问题 问题: Script file 'E:\Anaconda Distribution\Anaconda\Scripts\pip-script.py' is not ...

  4. 无法打开“&#215;&#215;&#215;”,因为无法确认开发者的身份——解决办法

    当打开这些应用程序时,系统提示无法打开" XXX",因为它来自身份不明的开发者.我们可以按照下面的方法解决. 教程 1.打开应用程序,找到你要打开的软件.按住control键,点击 ...

  5. 博文推荐|多图详解 Apache Pulsar 消息存储模型

    关于 Apache Pulsar Apache Pulsar 是 Apache 软件基金会顶级项目,是下一代云原生分布式消息流平台,集消息.存储.轻量化函数式计算为一体,采用计算与存储分离架构设计,支 ...

  6. .net 预处理指令符的使用

    目录 什么是预处理指令符? 预处理指令符的使用 自定义指令符 使用Visual Studio快速定义指令符 定义指令符区域 什么是预处理指令符? 当C#编译器找到一条预处理指令#if,最后找到一条指令 ...

  7. ASP.NET扩展库之Http日志

    最佳实践都告诉我们不要记录请求的详细日志,因为这有安全问题,但在实际开发中,请求的详细内容对于快速定位问题却是非常重要的,有时也是系统的强力证据.Xfrogcn.AspNetCore.Extensio ...

  8. IIS误删了默认网站,恢复方法

    有时候安装好IIS后,会不小心把IIS的默认网站删除.重新去新建可能会出现一些错误例如"提示文件已存在无法执行"等奇怪的错误,下面是具体的默认网站的恢复方法 找到目录C:\wind ...

  9. 通过Dapr实现一个简单的基于.net的微服务电商系统(二)——通讯框架讲解

    首先感谢张队@geffzhang公众号转发了上一篇文章,希望广大.neter多多推广dapr,让云原生更快更好的在.net这片土地上落地生根. 目录:一.通过Dapr实现一个简单的基于.net的微服务 ...

  10. 【笔记】《Redis设计与实现》chapter13 客户端

    服务器为每个客户端建立相应的redis.h/redisClient结构,这个结构保存了客户端当前的状态信息 客户端的套接字描述符 客户端的名字 客户端的标志值 只想客户端正在使用的数据库的指针,以及该 ...