[置顶] Mysql存储过程入门知识

时间:2022-03-27 09:42:18

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. &lbrack;置顶&rsqb; MySQL -- 创建函数&lpar;Function

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

  5. MySQL 存储过程入门

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

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

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

  7. &lbrack;置顶&rsqb; IOS 基础入门教程

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

  8. MySQL存储过程入门基础

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

  9. &lbrack;置顶&rsqb; mysql中的set和enum类型的用法和区别

    mysql中的enum和set其实都是string类型的而且只能在指定的集合里取值,  不同的是set可以取多个值,enum只能取一个值.   CREATE TABLE `20121101_t` ( ...

随机推荐

  1. ActiveReports 9 新功能:可视化查询设计器&lpar;VQD&rpar;介绍

    在最新发布的ActiveReports 9报表控件中添加了多项新功能,以帮助你在更短的时间里创建外观绚丽.功能强大的报表系统,本文将重点介绍可视化数据查询设计器,无需手动编写任何SQL语句,主要内容如 ...

  2. JiaThis WordPress分享插件安装全攻略

    WordPress 是一个功能非常强大的博客系统,插件众多,易于扩充功能.安装和使用都非常方便.目前 WordPress 已经成为主流的 Blog 搭建平台.按照下面的方法,只需简单几步,就可轻松地将 ...

  3. sql2008&plus;vs2008安装心得以及详细教程分享

    第一步,我把原来装的vs2005+sql2005全部卸载了 第二步,下载VS2008同时下载sql2008: 第三步,开始安装VS2008专业版,网上有很多给出了微软的地址,在这里我也贴一个吧 htt ...

  4. mysql shell 备份脚本

    使用 mysqldump 备份数据库,通过 FTP 上传到备份服务器,同时在本地保留备份文件. 新建一个 Shell 脚本文件 vi /home/work/backup.sh 添加如下内容: #! / ...

  5. ADO&period;NET 代码示例

    转自:http://msdn.microsoft.com/zh-cn/library/dw70f090 本主题中的代码列表演示如何使用下面的 ADO.NET 技术从数据库中检索数据: ADO.NET ...

  6. Centos 多个mysql数据库

    一.编译安装第一个MySQL 5.1.33 ? cd /opt   /usr/sbin/groupadd mysql   /usr/sbin/useradd -g mysql mysql -s /bi ...

  7. Sequence

    http://poj.org/problem?id=2442 用STL写的时间为:5657MS #include<cstdio> #include<algorithm> #in ...

  8. ch3-模板语法&lpar;&lbrace;&lbrace;&rcub;&rcub; v-html v-bind&colon;id 表达式 指令 修饰符 过滤器&rpar;

    1 模板语法 Vue.js 使用了基于 HTML 的模版语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据. 所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器 ...

  9. python 基础 内置函数 和lambda表达式

    1.把任意数值转化为字符串有两种方法. (1)str()用于将数值转化为易于人读的形式.print(str("我是中国人"))>>>我是中国人 (2)repr() ...

  10. 关于NOIP2018初赛

    题面 这次PJ初赛有点傻了,可能是因为兴华水土不服吧(在这荒度了六年级的光阴). 选择题 DDDBBAAAABABBBB 第四题 当时懵了,我啥也不知道,于是就开始蒙 A.LAN B.WAN C.MA ...