Mysql存储过程入门知识

#1,查看数据库所有的存储过程名
#--这个语句被用来移除一个存储程序。不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程
#SELECT NAME FROM mysql.proc WHERE db='数据库名'; 
#2,列出所有的存储过程
#SHOW PROCEDURE STATUS;
#3,查看存储过程详细
#SHOW CREATE PROCEDURE 数据库名.存储过程名;  
#4,存储过程的创建 由括号包围的参数列必须总是存在。如果没有参数,也该使用一个空参数列()。
#每个参数默认都是一个IN参数。要指定为其它参数,可在参数名之前使用关键词 OUT或INOUT
#CREATE PROCEDURE存储过程名 (参数列表); 使用BEGIN ... END复合语句来包含多个语句
# BEGIN
# SQL语句代码块
# END
#5,DECLARE语句(用来声明局部变量);
#要给变量提供一个默认值,需包含一个DEFAULT子句。如果没有DEFAULT子句,初始值为NULL。局部变量的作用范围在它被声明的BEGIN ... END块内。
#DECLARE var_name[,...] type [DEFAULT value] 
#6,变量SET语句
#SET var_name = expr [, var_name = expr]  
#7,SELECT ... INTO语句;这个SELECT语法把选定的列直接存储到变量,因此,只有单一的行可以被取回。
#SELECT col_name[,...] INTO var_name[,...] table_expr
#8,修改存储过程
#ALTER PROCEDURE 存储过程名SQL语句代码块;  
#9,删除存储过程
#DROP PROCEDURE IF EXISTS 存储过程名;
#存储过程的调用;存储过程名称后面必须加括号,哪怕该存储过程没有参数传递。
#10,CALL 存储过程名(参数列表);  
#11,MySQL 存储过程参数(in;)
#跟 C 语言的函数参数的值传递类似, MySQL 存储过程内部可能会修改此参数,但对 in 类型参数的修改,对调用者(caller)来说是不可见的(not visible)。
#12,MySQL 存储过程参数(out)
#MySQL 存储过程 “out” 参数:从存储过程内部传值给调用者。在存储过程内部,该参数初始值为 null,无论调用者是否给存储过程参数设置值
#13,MySQL 存储过程参数(inout)
#MySQL 存储过程 inout 参数跟 out 类似,都可以从存储过程内部传值给调用者。不同的是:调用者还可以通过 inout 参数传递值给存储过程。
#注:如果仅仅想把数据传给 MySQL 存储过程,那就使用“in” 类型参数;
# 如果仅仅从 MySQL 存储过程返回值,那就使用“out” 类型参数;
# 如果需要把数据传给 MySQL 存储过程,还要经过一些计算后再传回给我们,此时,要使用“inout” 类型参数。 #demo1:创建一个简单的存储过程(获取用户总数),带输出参数。
#--删除存储过程
DROP PROCEDURE IF EXISTS proc_users_getCount
#--创建存储过程
CREATE PROCEDURE proc_users_getCount(OUT n INT)
BEGIN
SELECT COUNT(*) FROM users ;
END
#--MYSQL调用存储过程
CALL proc_users_getCount(@n); #demo2:创建一个简单的存储过程(根据用户id获取用户信息),带输入参数。
#--删除存储过程
DROP PROCEDURE IF EXISTS proc_users_findById;
#--创建存储过程
CREATE PROCEDURE proc_users_findById(IN n INT)
BEGIN
SELECT * FROM users WHERE id=n;
END
#--定义变量
SET @n=1;
#--调用存储过程
CALL proc_users_findById(@n); #Last:操作存储过程时应注意:
#1.删除存储过程时只需要指定存储过程名即可,不带括号;
#2.创建存储过程时,不管该存储过程有无参数,都需要带括号;
#3.在使用SET定义变量时应遵循SET的语法规则;
#SET @变量名=初始值;
#4.在定义存储过程参数列表时,应注意参数名与数据库中字段名区别开来,否则将出现无法预期的结果. #END:java中调用存储过程util
# // 执行存储过程
# @Override
# public ResultSet execProc(final String procName, final Object[] params) {
# return (ResultSet) getHibernateTemplate().execute(
# new HibernateCallback() {
# public Object doInHibernate(Session session)
# throws HibernateException, SQLException {
# CallableStatement cstmt = session.connection()
# .prepareCall(procName);
# if (params != null) {
# for (int i = 0; i < params.length; i++) {
# cstmt.setObject(i + 1, params[i]);
# }
# }
# ResultSet rs = cstmt.getResultSet();
# return rs;
# }
# });
# }

[置顶] Mysql存储过程入门知识的更多相关文章

  1. MySQL存储过程入门

    MySQL存储过程入门 在本教程中,我们将逐步介绍如何使用CREATE PROCEDURE语句开发第一个MySQL存储过程. 另外,我们将向您展示如何从SQL语句调用存储过程. 编写第一个MySQL存 ...

  2. Mysql存储过程入门介绍

    delimiter //一般情况下MYSQL以:结尾表示确认输入并执行语句,但在存储过程中:不是表示结束,因此可以用该命令将:号改为//表示确认输入并执行. 一.创建存储过程 1.基本语法: crea ...

  3. MySQL存储过程入门教程

    存储过程介绍 存储过程是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中.用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它.存储过程可由应用程序通过一个调用来执行,而且 ...

  4. [置顶] MySQL -- 创建函数(Function

    目标 如何在MySQL数据库中创建函数(Function) 语法 CREATE FUNCTION func_name ( [func_parameter] ) //括号是必须的,参数是可选的 RETU ...

  5. MySQL 存储过程入门

    存储过程是带有逻辑的SQL语句,优点是执行效率高.缺点是可移植性差 1.存储过程语法 DELIMITER $ --声明结束符 CREATE PROCEDURE pro_test() --创建存储过程 ...

  6. [置顶] MySQL Cluster初步学习资料整理--安装部署新特性性能测试等

    1.1 mysql-cluster简介 简单的说,MySQLCluster实际上是在无共享存储设备的情况下实现的一种完全分布式数据库系统,其主要通过NDBCluster(简称NDB)存储引擎来实现. ...

  7. [置顶] IOS 基础入门教程

    IOS 基础入门教程 教程列表: IOS 简介 IOS环境搭建 Objective C 基础知识 创建第一款iPhone应用程序 IOS操作(action)和输出口(Outlet) iOS - 委托( ...

  8. MySQL存储过程入门基础

    创建存储过程无参语法: delimiter // create procedure 函数名() begin 业务逻辑 end // call 函数名() 通过函数名调用存储过程 创建存储过程有参与法: ...

  9. MySQL存储过程入门了解

    0.环境说明: mysql版本:5.7 1.使用说明 ​ 存储过程是数据库的一个重要的对象,可以封装SQL语句集,可以用来完成一些较复杂的业务逻辑,并且可以入参出参(类似于java中的方法的书写). ...

随机推荐

  1. 将文件放到Android模拟器的SD卡中的两种解决方法

    两种方式:一.窗口界面操作1.打开DDMS页面2.打开File Explorer页,如果没有,在Window --> Show View -->File Explorer3.一般就在mnt ...

  2. 线性表之顺序表(C语言实现)

    线性表是从数据元素的逻辑结构上定义的. 这种数据元素的逻辑结构的特征如下: 1.除开第一个和最后一个元素之外.所有元素都有一个前驱元素和后继元素. 2.第一个元素无前驱元素,但有后继元素. 3.最后一 ...

  3. poj1458 dp入门

    Common Subsequence Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 37551   Accepted: 15 ...

  4. poj 2425 A Chess Game_sg函数

    题意:给你一个有向无环图,再给你图上的棋子,每人每次只能移动一个棋子,当轮到你不能移动棋子是就输了,棋子可以同时在一个点 比赛时就差这题没ak,做了几天博弈终于搞懂了. #include <io ...

  5. php IP string与整型互换

    PHP中有内置函数ip2long可以将ip地址转换整型. 使用long2ip把整型转换回ip地址 例子: $ip = '58.6.207.207'; $ip_int = ip2long($ip); e ...

  6. AspectJ教学

    这几天看JAVA基础看的有点头疼,决定时不时的换换口味,准备開始调研一些如今流行的技术,于是,開始埋头思考自己知识的盲区(当时,自己的知识盲区茫茫多...),想了几天后,决定要開始研究一下几种技术及实 ...

  7. Zepto 使用中的一些注意点

    Zepto 只针对移动端浏览器编写,因此体积更小.效率更高,更重要的是,它的 API 完全仿照 jQuery ,所以学习成本也很低. 但是在开发过程中,我发现 Zepto 还远未成熟,其中包含了一些或 ...

  8. 【MFC学习笔记-作业6-sin图像】【OnDraw(CDC* pDC)】

    根据这段源代码 一步一步剖析CDC的使用 void CDrawSinXView::OnDraw(CDC* pDC) { CDrawSinXDoc* pDoc = GetDocument(); ASSE ...

  9. idea git merge代码

    1.点击idea 右下角的红框区域 2.出现如下截图,第一个红框是本地dev merge,也就是说可以从从本地的dev仓库merge,第二个红框表明可以从远程的git dev merge 第三个红框表 ...

  10. java中的302和sendRedirect的区别

    java中有一个sendRedirect函数这个用于跳转到另外一个页面,这个实际上是一个302跳转,但是不完全等同于302跳转 点击(此处)折叠或打开 response.sendRedirect(&q ...