Mysql容易存储过程入门示例与Java调用
Mysql简单存储过程入门示例与Java调用 ??? ?昨天看了一篇介绍Mysql存储过程博客,链接如下: ???? http://my.oschina.net/u/1264926/blog/199831 ???? 我试着运行了下,一直报错,找了很久才发现Mysql存储过程赋值要用SET 变量名 = 表达式值,很久没有Mysql存
Mysql简单存储过程入门示例与Java调用??? ?昨天看了一篇介绍Mysql存储过程博客,链接如下:
???? http://my.oschina.net/u/1264926/blog/199831
???? 我试着运行了下,一直报错,找了很久才发现Mysql存储过程赋值要用SET 变量名 = 表达式值,很久没有Mysql存储过程,好多东西都忘光了,而是写了本篇博文备忘,我使用的数据库版本是Mysql 5.6.14,使用了Navicat Premium图形界面,首先是我参考的链接:
????
http://www.cnblogs.com/jevo/p/3271359.html http://phpzf.blog.51cto.com/3011675/793775
??? 下面开始介绍Mysql存储过程,语法之类的我就不写了,请自行谷歌,我的存储过程是完成1到limit之间的累加和,所以要用到循环,Mysql存储过程常用的循环语句有:While,Loop,Repeat,下面一一介绍怎么写:
??? (一)首先是使用While循环(WHILE……DO……END WHILE)
???
create procedure proc_mysql_getsum_bywhile(in v_limit int,out sum int) begin declare i int default 0; set sum=0; while i<v_limit do begin set sum="sum+i;" i="i+1;" end while> <p>??? <span>这里啰嗦一句,Mysql里面没有类似Oracle的DBMS_OUT.PUT_LINE之类的打印语句,想打印结果,请用select 变量。</span></p> <p><span>?? While循环测试:</span></p> <p>???</p> <pre name="code" class="java">set @limit=100; set @out=0; call proc_mysql_getsum_bywhile(@limit,@out); select @out
?? (二)repeat 循环(REPEAT……END REPEAT)
??
create procedure proc_mysql_getsum_byrepeat(in v_limit int,out sum int) begin declare i int default 0; set sum=0; repeat begin set sum=sum+i; set i=i+1; end; until i>v_limit end repeat; /**select sum;**/ end;
??? Repeat测试:
???
set @limit=100; set @out=0; call proc_mysql_getsum_byrepeat(@limit,@out); select @out
??? (三)loop循环
???
create procedure proc_mysql_getsum_byloop(in v_limit int,out sum int) begin declare i int default 0; set sum=0; loop_label:loop begin set sum=sum+i; set i=i+1; if i>v_limit then leave loop_label; end if; end; end loop; /**select sum;**/ end;
??? loop 测试:
???
set @limit=100; set @out=0; call proc_mysql_getsum_byloop(@limit,@out); select @out
??? 上面介绍的是一个简单的带输入输出的存储过程,下面在介绍一个getUserById的存储过程,和上面的差不多。
??
create procedure proc_mysql_inout_test(in v_id int,out username varchar(20)) begin select username into username from user_t2 where id = v_id; /**select username;**/ end;
??? in out参数测试:
??? Navicat查询界面测试:
???
call proc_mysql_inout_test(2,@out); select @out
??? 返回值很奇怪结果是Blob。
??
??? Navicat命令行下测试:返回的是gbk编码的字符串,而直接select * from user_t2;无乱码,如下所示:
???
??? cmd 命令行下测试 无乱码,如下所示:
???
??? 如果想在存储过程中执行sql语句该怎么写呢?请看示例:
????测试新建表并填充值:
???
drop PROCEDURE proc_mysql_createtb_insert_data; CREATE PROCEDURE proc_mysql_createtb_insert_data(IN loop_times INT) BEGIN DECLARE var INT DEFAULT 0; PREPARE MSQL FROM 'CREATE TABLE IF NOT EXISTS mysql_employee (id INT (10) NOT NULL AUTO_INCREMENT,empname VARCHAR (16) NOT NULL COMMENT ''名字'',hiredate TIMESTAMP DEFAULT CURRENT_TIMESTAMP,PRIMARY KEY (id)) ENGINE = INNODB DEFAULT CHARSET = utf8'; EXECUTE MSQL; deallocate prepare MSQL; WHILE var<loop_times do set var="var+1;" insert into mysql_employee values substr from dual end while> <p>??? <span>测试</span><br>???</p> <pre name="code" class="sql">call proc_mysql_createtb_insert_data(10); select * from mysql_employee;
??
?? Mysql存储过程想要修改时只能先删除在新建,删除方法为:
??
drop procedure proc_mysql_getsum_bywhile
?? 查看某个数据库下面的存储过程方法为:
??
select name from mysql.proc where db='test'
?? 如果想和Oracle存储过程一样返回游标,怎么写呢,很遗憾,我所知道的是Mysql不支持Out ref_cur cursor之类的写法的,你可以在存储过程中新建临时表,结束时候删除临时表,方法请参考上面的新建表示例。
?? 另一种方法是直接select 内容,不写返回结果,如下所示:
??
CREATE PROCEDURE proc_mysql_return_cursor_method() begin select * from user_t2; end;
??? 测试方法为:
???
call proc_mysql_return_cursor_method();
??? 下面我简单介绍下Java中怎么调用Mysql存储过程,如果不感兴趣可以不用往下看了。
??? 首先是公共方法:
???
public Connection getMysqlConnection() { String driver = "com.mysql.jdbc.Driver"; String url = "jdbc:mysql://localhost:3306/test";// 要操作的数据库名称 String username = "root";// 数据库用户名 String password = "123";// 密码 return getConnection(driver, url, username, password); } public Connection getConnection(String driver, String url, String userName, String passwd) { Connection conn = null; try { Class.forName(driver); conn = DriverManager.getConnection(url, userName, passwd); } catch (Exception e) { e.printStackTrace(); } return conn; }
?? 我就以我写的while循环为例,输入int参数,输出int参数:
??
public void testMysqlProcedureRtnInt(Connection con, CallableStatement cs, int limit) throws Exception { cs = con.prepareCall("{call proc_mysql_getsum_bywhile(?,?)}"); // 设置参数 cs.setInt(1, limit); // 注册输出参数 cs.registerOutParameter(2, oracle.jdbc.OracleTypes.INTEGER); // 执行过程 cs.execute(); // 获取结果 int result = cs.getInt(2); System.out.println("结果为:" + result); }
?? 输入int,输出varchar类型方法类似:
??
public void testMysqlProcedureRtnVarchar(Connection con, CallableStatement cs, int id) throws Exception { cs = con.prepareCall("{call proc_mysql_inout_test(?,?)}"); // 设置参数 cs.setInt(1, id); // 注册输出参数 cs.registerOutParameter(2, oracle.jdbc.OracleTypes.VARCHAR); // 执行过程 cs.execute(); // 获取结果 String result = cs.getString(2); System.out.println("结果为:" + result); }
??? 来看下返回类似游标类型的调用:
???
public void testMysqlProcedureRtnCursor(Connection con, CallableStatement cs, ResultSet rs) throws Exception { cs = con.prepareCall("{call proc_mysql_return_cursor_method()}"); // 执行过程 rs = cs.executeQuery(); System.out.println("id" + "\t" + "username" + "\t" + "passwd"); while (rs.next()) { System.out.println(rs.getInt(1) + "\t" + rs.getString(2) + "\t" + rs.getString(3)); } }
??? 很简单吧。
??? 上面的介绍到目前为知该结束了,本文系原创,转载请注明出处,谢谢。
???? 全文完。
??
???

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题











MySQL是一种开源的关系型数据库管理系统,主要用于快速、可靠地存储和检索数据。其工作原理包括客户端请求、查询解析、执行查询和返回结果。使用示例包括创建表、插入和查询数据,以及高级功能如JOIN操作。常见错误涉及SQL语法、数据类型和权限问题,优化建议包括使用索引、优化查询和分表分区。

PHP是一种广泛应用于服务器端的脚本语言,特别适合web开发。1.PHP可以嵌入HTML,处理HTTP请求和响应,支持多种数据库。2.PHP用于生成动态网页内容,处理表单数据,访问数据库等,具有强大的社区支持和开源资源。3.PHP是解释型语言,执行过程包括词法分析、语法分析、编译和执行。4.PHP可以与MySQL结合用于用户注册系统等高级应用。5.调试PHP时,可使用error_reporting()和var_dump()等函数。6.优化PHP代码可通过缓存机制、优化数据库查询和使用内置函数。7

PHP适合web开发,特别是在快速开发和处理动态内容方面表现出色,但不擅长数据科学和企业级应用。与Python相比,PHP在web开发中更具优势,但在数据科学领域不如Python;与Java相比,PHP在企业级应用中表现较差,但在web开发中更灵活;与JavaScript相比,PHP在后端开发中更简洁,但在前端开发中不如JavaScript。

MySQL在数据库和编程中的地位非常重要,它是一个开源的关系型数据库管理系统,广泛应用于各种应用场景。1)MySQL提供高效的数据存储、组织和检索功能,支持Web、移动和企业级系统。2)它使用客户端-服务器架构,支持多种存储引擎和索引优化。3)基本用法包括创建表和插入数据,高级用法涉及多表JOIN和复杂查询。4)常见问题如SQL语法错误和性能问题可以通过EXPLAIN命令和慢查询日志调试。5)性能优化方法包括合理使用索引、优化查询和使用缓存,最佳实践包括使用事务和PreparedStatemen

PHP成为许多网站首选技术栈的原因包括其易用性、强大社区支持和广泛应用。1)易于学习和使用,适合初学者。2)拥有庞大的开发者社区,资源丰富。3)广泛应用于WordPress、Drupal等平台。4)与Web服务器紧密集成,简化开发部署。

PHP和Python各有优势,适合不同场景。1.PHP适用于web开发,提供内置web服务器和丰富函数库。2.Python适合数据科学和机器学习,语法简洁且有强大标准库。选择时应根据项目需求决定。

选择MySQL的原因是其性能、可靠性、易用性和社区支持。1.MySQL提供高效的数据存储和检索功能,支持多种数据类型和高级查询操作。2.采用客户端-服务器架构和多种存储引擎,支持事务和查询优化。3.易于使用,支持多种操作系统和编程语言。4.拥有强大的社区支持,提供丰富的资源和解决方案。

Apache 连接数据库需要以下步骤:安装数据库驱动程序。配置 web.xml 文件以创建连接池。创建 JDBC 数据源,指定连接设置。从 Java 代码中使用 JDBC API 访问数据库,包括获取连接、创建语句、绑定参数、执行查询或更新以及处理结果。
