mysql编程--从入门到入土

2024-06-19 16:12

本文主要是介绍mysql编程--从入门到入土,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    • 创建存储过程
    • 调用存储过程
    • 删除存储过程
    • 可能出现的问题
    • MySQL变量
      • 系统变量
    • 定义变量
    • 查询变量
    • 变量的简单使用
    • 局部变量
    • if语句
    • 参数

创建存储过程

create procedure p()
begin
select * from emp;
end;

调用存储过程

call p;

删除存储过程

drop procedure if exists p;

可能出现的问题

在dos命令窗口时,遇到分号则会执行语句。解决办法:运行下方语句,服务器不再会遇到分号结尾了,而是两个斜杠
delimiter// – 告诉服务器,遇到两个斜杠再执行sql语句

MySQL变量

系统变量

系统变量由系统提供,不是用户定义的,属于服务器层面

查看系统变量

show global variables; -- 全局的
show session variables;-- 当前会话的(当前连接)

设置系统变量

set [global I session] 系统变量名 =;

注意:当MySQL服务重启后,之前的配置会失效

定义变量

set @name = '张三';
定义一个变量name,值为张三

查询变量

select @name;
-- 查询多个变量
select @name,@age,@sex,@information;
注:如果没有声明变量直接查询的话结果为null

变量的简单使用

-- 我们也可以在查询中调用变量
select * from student where ename=@name;
-- 同时也可以将查询结果赋值给变量
select age into @age from student where ename='张三';

局部变量

在存储过程中可以使用变量,使用declare声明,只在begin和end之间有效
CREATE DEFINER=`root`@`localhost` PROCEDURE `pee`()
BEGIN
-- 声明两个变量declare age int default 0;
-- 为变量赋值set age =18;
END

if语句

语法格式:

if 条件 then...
else if 条件 then...
else if 条件 then...
else...
end if

实战练习:
通过工资来判断收入群体,sal超过10000的为高收入群体,5000以上为中等收入群体,5000一下 为低收入群体

CREATE PROCEDURE p()
begin declare sal int default 0;declare result varchar(20);set sal := 5001;if sal>10000 thenset result = '高收入';elseif sal>5000 thenset result = '中等收入';elseset result = '低收入';end if;select result;
end

参数

in:入参(未指定时,默认入参)写入数据但并不导出
out:出参 不写入数据,输出参数
inout:既入参又出参

CREATE PROCEDURE sal(in sal int,out result varchar(20))
# 此处我们定义了一个sal(工资),result输出结果,这两个变量均欸局部变量,在存储过程外只能访问到用户变量,但result作为一个输出结果,在存储过程外我们是能查到的
begin 
# 我们在创建存储过程时已经定义了sal,此时我们无需再定义值if sal>10000 thenset result = '高收入';elseif sal>5000 thenset result = '中等收入';elseset result = '低收入';end if;select result;
end# 调用存储过程call sal(7000,@result); -- 在sal数据处写入值,运行存储过程,因为我们没有输出语句此时没有任何内容被输出#查询我们曾赋值的result,输出结果select @result
create procedure p1(inout sal int) #此时定义inout即是入参又是出参
beginset sal=sal*1.1;
end;set @sal=10000;  #定义sal,此时的sal与上方的sal无关,只是一个赋值的变量,所以变量名随意,下方同理,但要与这行定义的函数相匹配
call p1(@sal);   #给存储过程赋值,输出结果会直接赋值到sal变量上
select @sal; 	 #查询变量

这篇关于mysql编程--从入门到入土的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1075509

相关文章

MySQL zip安装包配置教程

《MySQLzip安装包配置教程》这篇文章详细介绍了如何使用zip安装包在Windows11上安装MySQL8.0,包括下载、解压、配置环境变量、初始化数据库、安装服务以及更改密码等步骤,感兴趣的朋... 目录mysql zip安装包配置教程1、下载zip安装包:2、安装2.1 解压zip包到安装目录2.2

MySQL安装时initializing database失败的问题解决

《MySQL安装时initializingdatabase失败的问题解决》本文主要介绍了MySQL安装时initializingdatabase失败的问题解决,文中通过图文介绍的非常详细,对大家的学... 目录问题页面:解决方法:问题页面:解决方法:1.勾选红框中的选项:2.将下图红框中全部改为英

MySQL 中的服务器配置和状态详解(MySQL Server Configuration and Status)

《MySQL中的服务器配置和状态详解(MySQLServerConfigurationandStatus)》MySQL服务器配置和状态设置包括服务器选项、系统变量和状态变量三个方面,可以通过... 目录mysql 之服务器配置和状态1 MySQL 架构和性能优化1.1 服务器配置和状态1.1.1 服务器选项

MySQL8.0设置redo缓存大小的实现

《MySQL8.0设置redo缓存大小的实现》本文主要在MySQL8.0.30及之后版本中使用innodb_redo_log_capacity参数在线更改redo缓存文件大小,下面就来介绍一下,具有一... mysql 8.0.30及之后版本可以使用innodb_redo_log_capacity参数来更改

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE