mysql存储优化方法
概述在数据库的开发过程中,经常会遇到复杂的业务逻辑和对数据库的操作,这个时候就会用存储过程来封装数据库操作。如果项目的存储过程较多,书写又没有一定的规范,将会影响以后的系统维护困难和大存储过程逻辑的难...
2024.11.13简单的说,就是一组SQL语句集,功能强大,可以实现一些比较复杂的逻辑功能,类似于JAVA语言中的方法;
ps:存储过程跟触发器有点类似,都是一组SQL集,但是存储过程是主动调用的,且功能比触发器更加强大,触发器是某件事触发后自动调用;
存储过程特性有输入输出参数,可以声明变量,有if/else, case,while等控制语句,通过编写存储过程,可以实现复杂的逻辑功能;函数的普遍特性:模块化,封装,代码复用;速度快,只有首次执行需经过编译和优化步骤,后续被调用可以直接执行,省去以上步骤;MySQL存储过程的创建1、语法
CREATE PROCEDURE sp_name ([proc_parameter[,...]]) [characteristic ...] routine_body
CREATE PROCEDURE 过程名([[IN|OUT|INOUT] 参数名 数据类型[,[IN|OUT|INOUT] 参数名 数据类型…]]) [特性 ...] 过程体
delimiter // CREATE PROCEDURE myproc(OUT s int) BEGIN select COUNT(*) INTO s FROM students; END //delimiter ;MySQL默认以";"为分隔符,如果没有声明分割符,则编译器会把存储过程当成SQL语句进行处理,因此编译过程会报错,所以要事先用“delimiter //”声明当前段分隔符,让编译器把两个"//"之间的内容当做存储过程的代码,不会执行这些代码;“delimiter ;”的意为把分隔符还原。
2、参数
存储过程根据需要可能会有输入、输出、输入输出参数,如果有多个参数用","分割开。MySQL存储过程的参数用在存储过程的定义,共有三种参数类型,IN,OUT,INOUT:
IN参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值OUT:该值可在存储过程内部被改变,并可返回INOUT:调用时指定,并且可被改变和返回其中,sp_name参数是存储过程的名称;proc_parameter表示存储过程的参数列表; characteristic参数指定存储过程的特性;routine_body参数是SQL代码的内容,可以用BEGIN…END来标志SQL代码的开始和结束。
技巧:创建存储过程时,系统默认指定CONTAINS SQL,表示存储过程中使用了SQL语句。但是,如果存储过程中没有使用SQL语句,最好设置为NO SQL。而且,存储过程中最好在COMMENT部分对存储过程进行简单的注释,以便以后在阅读存储过程的代码时更加方便。
存储过程实例下面创建一个名为num_from_employee的存储过程。
上述存储过程名称为num_from_employee;输入变量为emp_id;输出变量为count_num。select语句从employee表查询d_id值等于emp_id的记录,并用COUNT(*)计算d_id值相同的记录的条数,最后将计算结果存入count_num中。执行结果如下:
执行完毕后,没有报出任何出错信息就表示存储函数已经创建成功。以后就可以调用这个存储过程,数据库中会执行存储过程中的SQL语句。
说明:MySQL中默认的语句结束符为分号(;)。存储过程中的SQL语句需要分号来 结束。为了避免冲突,首先用"delimiter &&"将MySQL的结束符设置为&&。最后再用"delimiter ;"来将结束符恢复成分号。这与创建触发器时是一样的。
函数在MySQL中,创建存储函数的基本形式如下:
CREATE FUNCTION sp_name ([func_parameter[,...]]) RETURNS type [characteristic ...] routine_body其中,sp_name参数是存储函数的名称;func_parameter表示存储函数的参数列表;RETURNS type指定返回值的类型;characteristic参数指定存储函数的特性,该参数的取值与存储过程中的取值是一样的;routine_body参数是SQL代码的内容,可以用BEGIN…END来标志SQL代码的开始和结束。
func_parameter可以由多个参数组成,其中每个参数由参数名称和参数类型组成,其形式如下:param_name type
其中,param_name参数是存储函数的参数名称;type参数指定存储函数的参数类型,该类型可以是MySQL数据库的任意数据类型。
函数实例下面创建一个名为name_from_employee的存储函数。
上述存储函数的名称为name_from_employee;该函数的参数为emp_id;返回值是VARCHAR类型。select语句从employee表查询num值等于emp_id的记录,并将该记录的name字段的值返回。执行结果如下:
结果显示,存储函数已经创建成功。该函数的使用和MySQL内部函数的使用方法一样。
变量的使用在存储过程和函数中,可以定义和使用变量。用户可以使用declare关键字来定义变量。然后可以为变量赋值。这些变量的作用范围是BEGIN…END程序段中。
1、定义变量
MySQL中可以使用declare关键字来定义变量。定义变量的基本语法如下:
declare var_name[,...] type [DEFAULT value]其中, declare关键字是用来声明变量的;var_name参数是变量的名称,这里可以同时定义多个变量;type参数用来指定变量的类型;DEFAULT value子句将变量默认值设置为value,没有使用DEFAULT子句时,默认值为NULL。
下面定义变量my_sql,数据类型为INT型,默认值为10。
declare my_sql INT DEFAULT 10 ;2、为变量赋值
MySQL中可以使用SET关键字来为变量赋值。SET语句的基本语法如下:
SET var_name = expr [, var_name = expr] ...其中,SET关键字是用来为变量赋值的;var_name参数是变量的名称;expr参数是赋值表达式。一个SET语句可以同时为多个变量赋值,各个变量的赋值语句之间用逗号隔开。
下面为变量my_sql赋值为30。
SET my_sql = 30 ;MySQL中还可以使用select…INTO语句为变量赋值。其基本语法如下:
select col_name[,…] INTO var_name[,…] FROM table_name WEHRE condition其中,col_name参数表示查询的字段名称;var_name参数是变量的名称;table_name参数指表的名称;condition参数指查询条件。
下面从employee表中查询id为2的记录,将该记录的d_id值赋给变量my_sql。
select d_id INTO my_sql FROM employee WEHRE id=2 ;MySQL存储过程写法总结1、创建无参存储过程。
create procedure product()begin select * from user;end;一条简单的存储过程创建语句,此时调用的语句为:
call procedure();2、创建有参存储过程
有参的存储包括两种参数,
一个是传入参数;
一个是传出参数;
例如一个存储过程:
create procedure procedure2(out p1 decimal(8,2),out p2 decimal(8,2),in p3 int)beginselect sum(uid) into p1 from user where order_name = p3;select avg(uid) into p2 from user ;end ;从上面sql语句可以看出,p1和p2是用来检索并且传出去的值,而p3则是必须有调用这传入的具体值。
具体调用过程:
call product(); //无参
call procedure2(@userSum,@userAvg,201708); //有参
当用完后,可以直接查询userSum和userAvg的值:
select @userSum, @userAvg;
结果如下:
3、删除存储过程
语法:drop procedure procedure_name;
后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注一下~
概述在数据库的开发过程中,经常会遇到复杂的业务逻辑和对数据库的操作,这个时候就会用存储过程来封装数据库操作。如果项目的存储过程较多,书写又没有一定的规范,将会影响以后的系统维护困难和大存储过程逻辑的难...
2024.11.13目录二:MySQL存储过程变量及赋值三:MySQL存储过程的创建2. 使用navicat创建一个存储过程3. 存储过程中的参数:IN OUT INOUT四:MySQL存储过程的管理1. MySQL存储...
2024.11.15什么是存储过程简单的说,就是一组SQL语句集,功能强大,可以实现一些比较复杂的逻辑功能,类似于JAVA语言中的方法;ps:存储过程跟触发器有点类似,都是一组SQL集,但是存储过程是主动调用的,且功能比...
2024.11.151、概述开发MySQL存储过程时,经常需要写循环逻辑;MySQL中支持三种循环分别是WHILE循环,REPEAT循环以及LOOP循环。循环语句的格式如下:WHILE……DO……END WHILEREP...
2024.11.12概述由MySQL5.0 版本开始支持存储过程。如果在实现用户的某些需求时,需要编写一组复杂的SQL语句才能实现的时候,那么我们就可以将这组复杂的SQL语句集提前编写在数据库中,由JDBC调用来执行这组...
2024.11.14