mybatis 调用mysql存储过程 带输出输入参数

http://lohasle.iteye.com/blog/1669879

存储过程都是一样的,只是根据自己的喜好,可以用MAP或者JAVABEAN传递参数。

Sql代码  

  1. -- --------------------------------------------------------------------------------
  2. -- Routine DDL
  3. -- Note: comments before and after the routine body will not be stored by the server
  4. -- --------------------------------------------------------------------------------
  5. DELIMITER $$
  6. CREATE DEFINER=`root`@`localhost` PROCEDURE `selectCount`(
  7. IN pcsId int,
  8. IN drId int,
  9. IN partnerId int,
  10. IN customerId int,
  11. OUT pcsCount int,
  12. OUT drCount int
  13. )
  14. BEGIN
  15. select count(md.id) into @pcsC from mdm_device md
  16. left join mdm_device_security mds on mds.device_id = md.id
  17. where mds.device_rooted = pcsId
  18. and md.partner_id = partnerId and md.customer_id = customerId;
  19. set pcsCount = @pcsC;
  20. select count(md.id) into @drC from mdm_device md
  21. where md.managed_status = drId and  DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(md.un_manage_date)
  22. and md.partner_id = partnerId and md.customer_id = customerId;
  23. set drCount = @drC;
  24. END

1.java调用传入MAP。获取通过MAP获取。

1.1 mapper文件写法

Xml代码  

  1. <parameterMap type="map" id="homeVO">
  2. <parameter property="pcsId" jdbcType="INTEGER" mode="IN"/>
  3. <parameter property="drId" jdbcType="INTEGER" mode="IN"/>
  4. <parameter property="partnerId" jdbcType="INTEGER" mode="IN"/>
  5. <parameter property="customerId" jdbcType="INTEGER" mode="IN"/>
  6. <parameter property="pcsCount" jdbcType="INTEGER" mode="OUT"/>
  7. <parameter property="drCount" jdbcType="INTEGER" mode="OUT"/>
  8. </parameterMap>
  9. <select id="selectForHome" parameterMap="homeVO"
  10. statementType="CALLABLE">
  11. {call selectCount(
  12. ?,?,?,?,?,?
  13. )}
  14. </select>

1.2 java调用写法

Java代码  

  1. @Override
  2. public StringselectHomeCount(HomeVO home) throws Exception {
  3. Map<String, Object> map = new HashMap<String, Object>();
  4. map.put("pscId", 0);
  5. map.put("drId", 1);
  6. map.put("partnerId", 25);
  7. map.put("customerId", 50);
  8. map.put("isolation", 1);
  9. selectOne("Mapper.selectForHome", map);
  10. System.out.println(map.get("pcsCount"));
  11. return map.get("drCount");
  12. }

2.java调用传入javaBean。返回值通过javaBean属性获取

2.1 通过javabean传递参数  mapper写法

Xml代码  

  1. <parameterMap type="com.polysaas.mdm.device.entity.HomeVO" id="home">
  2. <parameter property="pcsId" jdbcType="INTEGER" mode="IN"/>
  3. <parameter property="drId" jdbcType="INTEGER" mode="IN"/>
  4. <parameter property="partnerId" jdbcType="INTEGER" mode="IN"/>
  5. <parameter property="customerId" jdbcType="INTEGER" mode="IN"/>
  6. <parameter property="pcsCount" jdbcType="INTEGER" mode="OUT"/>
  7. <parameter property="drCount" jdbcType="INTEGER" mode="OUT"/>
  8. </parameterMap>

javaBean可以通过两种来进行映射

Xml代码  

  1. <resultMap type="com.polysaas.mdm.device.entity.HomeVO" id="home">
  2. <result column="partnerId" property="partnerId" jdbcType="INTEGER"/>
  3. <result column="customerId" property="customerId" jdbcType="INTEGER" />
  4. <result column="pcsId" property="pcsId" jdbcType="INTEGER" />
  5. <result column="drId" property="drId" jdbcType="INTEGER" />
  6. <result column="pcsCount" property="pcsCount" jdbcType="INTEGER" />
  7. <result column="drCount" property="drCount" jdbcType="INTEGER" />
  8. </resultMap>
  9. <select id="selectForHome2" parameterType="com.polysaas.mdm.device.entity.HomeVO"
  10. statementType="CALLABLE">
  11. {call selectCount(
  12. #{pcsId,jdbcType=INTEGER, mode=IN},
  13. #{drId, jdbcType=INTEGER,mode=IN},
  14. #{partnerId, jdbcType=INTEGER,mode=IN},
  15. #{customerId, jdbcType=INTEGER,mode=IN},
  16. #{pcsCount, jdbcType=INTEGER,mode=OUT},
  17. #{drCount, jdbcType=INTEGER,mode=OUT}
  18. )}
  19. </select>

2.2 通过javabean传递参数  java调用写法

Java代码  

  1. @Override
  2. public HomeVO selectHomeCount(HomeVO home) throws Exception {
  3. HomeVO vo = new HomeVO();
  4. vo.setPcsId(0);
  5. vo.setDrId(0);
  6. vo.setPartnerId(25);
  7. vo.setCustomerId(50);
  8. vo.setPcsCount(0);
  9. vo.setDrCount(0);
  10. selectOne("com.polysaas.mdm.device.mapper.MdmDeviceMapper.selectForHome2", vo);
  11. return vo;
  12. }

遇到异常很多。。记得的写下

1.通过javaBean的时候,#{pcsId, mode=IN, javaType=INTEGER},javaType这个属性是必须的。

2.使用javaBean传递。输出参数不需要初始值。个人喜好并建议使用javaBean,因为定义更清晰,封装性。

3.map可以用占位符问号,javaBean不可以。  会有异常 No value specified for parameter 1

4.   说不认识某个参数。。可能是没有创建存储过程,这个发生在多个库的时候

5.  read Only  这个可能是事务控制只读。。我是因为存储过程有set 语句,而方法叫做selectAaaa()。

时间: 2024-10-10 00:37:36

mybatis 调用mysql存储过程 带输出输入参数的相关文章

mybatis调用mysql存储过程返回多结果集(完整)

最近,有个开发提了个需求,希望中间件支持调用mysql存储过程时支持多结果集返回,因为某些原因我们使用了不少的存储过程,很多复杂的逻辑目前来看交互非常的多,所以从当前的现状来说,这个需求还是蛮合理的.中午抽空特地搜了下,整合完整示例如下: 1.创建测试存储过程 delimiter $$ CREATE PROCEDURE sp_multi_resultset(IN p_operator_company_no int, IN p_operator_no int, OUT p_error_code v

mybatis调用mysql存储过程返回结果集

存储过程中经常需要返回结果集. Mysql 中直接用 select 即可返回结果集.而 oracle 则需要使用游标来返回结果集.这一点 Mysql 相对比较方便,如下代码即可实现输出结果集: 存储过程定义: DELIMITER $$ DROP procedure IF EXISTS pro_sql_data1 $$ CREATE procedure pro_sql_data1(in sear_name varchar(2000)) BEGIN if sear_name is not null

mybatis调用mysql存储过程

返回类似 select *from 的做法过程:create procedure selectAll()BEGINselect * from user;end xml配置:<select id="selectall" resultType="map" statementType="CALLABLE"> {call selectAll()} </select> java配置://service层调用List<Map&l

mybatis调用mysql的存储过程(procedure),实现查询操作(student表中的某个年级中的总人数 select (1) 或者 select (*))

step1:在mysql cmd中新建存储过程: drop procedure if exists queryCountByGrade ; delimiter // -- 定义存储过程结束符号为// create procedure queryCountByGrade(IN gradenameinput INT(11),OUT counts int(11) begin select count(*) into counts from student where grade = gradename

Mybatis调用PostgreSQL存储过程实现数组入参传递

注:本文来源于 < Mybatis调用PostgreSQL存储过程实现数组入参传递  > 前言 项目中用到了Mybatis调用PostgreSQL存储过程(自定义函数)相关操作,由于PostgreSQL自带数组类型,所以有一个自定义函数的入参就是一个int数组,形如: CREATE OR REPLACE FUNCTION "public"."func_arr_update"(ids _int4)... 1 如上所示,参数是一个int数组,Mybatis提

Mybatis使用MySQL模糊查询时输入中文检索不到结果怎么办--转自http://www.jb51.net/article/88236.htm

这篇文章主要介绍了Mybatis使用MySQL模糊查询时输入中文检索不到结果的解决办法的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下 项目开发中,在做Mybatis动态查询时,遇到了一个问题:MySQL在进行LIKE模糊查询时,输入英文可以正常检索出结果,但是输入中文后检索得到的结果为空. 由于是使用GET方式请求,所以为了确保中文不乱码,在控制台接收到请求参数后,对中文进行了一次编码. ? 1 2 3 4 5 try { realName = new String(realNam

PHP调用MYSQL存储过程实例

PHP调用MYSQL存储过程实例 标签: mysql存储phpsqlquerycmd 2010-09-26 11:10 11552人阅读 评论(3) 收藏 举报 实例一:无参的存储过程$conn = mysql_connect('localhost','root','root') or die ("数据连接错误!!!");mysql_select_db('test',$conn);$sql = "create procedure myproce()beginINSERT IN

mybatics 中调用mysql存储过程。

说起mybatics 框架,身边的java开发工程师们基本上都是耳熟能详. mybatics是apache的一个开源项目,前身为ibatics,2010年此项目由apache软件基金会迁移到了google code,mybatics的确是一款十分优秀的开源持久层框架,sql代码隔离封装.自动POJO映射.jdbc 动态sql---- mybatics的好处可以说出一箩筐,然而mybatics还有一个十分优秀的特性却往往被人忽略 ----那就是mybatics还支持存储过程的调用. 不熟悉存储过程

PHP多次调用Mysql存储过程报错解决办法

PHP多次调用Mysql数据库的存储过程会出现问题,主要问题为存储过程中执行多次SQL语句不能一一释放导致的,网上找了一些解决办法,比如使用 multi_query 然后一个一个释放,但是发现根本不适合我们的项目,我们使用CI框架写的,更多的是使用CI的数据库处理方法.所以只能另辟蹊径. 一次偶然,把Mysql链接方式改成了mysqli,两种不同的PHP连接mysql的扩展,官方在高版本中推荐使用mysqli,结果却奇迹般好了,使用Mysql长连接也行,天意么? PHP多次调用Mysql存储过程