一.调用存储过程 一.返回单个值 1.存储过程准备 这里先创建一个存储过程,传入参数为age,传出参数为count.然后先测试一下是否正确. CREATE DEFINER=`root`@`localhost` PROCEDURE `pro_get_usercountbyage`(in age int,out user_count int) BEGIN ) into user_count from user a where a.age=age; END DELIMITER ; ; CALL myb…
这里先吐槽下,写的半天的东西,IE浏览器弹出调试窗口导致写的东西全部没保存,搞得我还要重新用谷歌写,思路全没了,fuck. 前面学习了下spring的DAO层,说起DAO层,那ORM肯定是少不了的,ORM的框架也比较多,做C#的时候用EF,现在Java的话流行SSM,所以就想着学习下Mybatis,参考这EF的几篇博客,打算MyBatis这块也系统的学习下,主要涉及单表增删改查.属性与列名映射.表之间关系映射.事务与锁.存储过程.缓存.Spring与MyBatis结合这几块,可能随着深入的学习还…
什么是MyBatis? 答:它是一个持久层框架 说的太简单了吗?那让我们来看一下官方的文档描述: MyBatis有什么作用呢? 1.持久层的零实现 2.可以自动将数据封装到对象里面不需要手工编写映射的关系 MyBatis基于XML配置文件的配置流程图: 配置流程步骤及代码: 1.导入包: 2.创建总的配置文件 注意,要在设置中设置两个规则文件,第一个是用于总配置文件中,第二个是用于配置映射文件中,在配置中遇到PUBLIC ID 可在MyBatis的官方文档中找到 PUBLIC ID 总配置文件编…
上一博客主要是对单表的增删改查,比较简单,而且每个属性与table表的列都是一一对应名字也一样,今天主要学习属性与table表列名不一致的处理,主要有两种一是属性与列名不一致,二是枚举的情况,这里暂时考虑的属性与列名不一致只是单表的情况,至于属性如果是其他model涉及表与表之间的关系的放在下一博客.不过先介绍几个其他的知识点.这些都是参考官网http://www.mybatis.org/mybatis-3/zh/index.html,大家也可以直接参考官网的.本篇博客还是在上一篇博客的基础上做…
一.创建存储过程 存储过程的目的:统计edi_test_task 正在运行的任务和非运行的任务 CREATE DEFINER=`root`@`%` PROCEDURE `edihelper`.`SP_ISRunning_Count`(IN run_id INT ,OUT num INT) BEGIN IF run_id=0 THEN select count(*) from edi_test_task where is_running=true INTO num; ELSE select cou…
数据库表之间的关系有3种,一对一.一对多.多对多.既然是ORM,这肯定是必须有的.在学习EF的时候也有涉及,今天就是参考着EF的来学习下MyBatis的表关系映射. 一.准备工作 1.准备Model和Table 既然是要涉及表的一对一.一对多.多对多的关系,那肯定得先准备好实体关系,以及表.下面建了四个对象四个表.User<->Card是一对一关系,User<->Course一对多关系,User<->Role多对多关系. User CREATE TABLE `user`…
先说下我的梦想,大学的时候一直想着是能开店卖胡辣汤,到目前依然还是我的梦想,上周一家出版社联系我问我有没有时间可以合作出书,这也是我的梦想之一,想了想还是放弃了,至少觉得目前不行,毕竟工作还不到五年,出书我可不想误人子弟,还有就是将来能办个培训班,这个我觉得还不错,所以也是我坚持写博客的原因之一.装逼结束,开始正题. 计划着能在年前把MyBatis学个差不多,所以上周是逼自己一把,连着3天一直在看Mybatis.前面把MyBatis中的表映射.列映射和增删改查大致了解了一下,今天主要学习动态sq…
在mybatis的映射xml文件调用java类的方法:使用的是OGNL表达式,表达式格式为:${@prefix@methodName(传递参数名称)} 1.如下代码所示:方法必须为静态方法:以下我只是演示如何使用,随便用到了一个工具类SELECT * FROM USER WHERE name='${@org.apache.commons.lang3@StringUtils(name)}' 2.获取类里面的常量,获取的格式和上面一样,第二个@是常量 : ${@classpath@ static c…
注:本case参考自:http://www.cnblogs.com/ysocean/p/7277545.html 一:Mybatis的介绍: MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis .2013年11月迁移到Github. iBATIS一词来源于"internet"和"abatis"的组合,是一个基于Java的持久层…
本文转载自:http://www.cnblogs.com/jpf-java/p/6013518.html 一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据库表和存储过程 1 create table p_user( 2 id int primary key auto_increment, 3 name varchar(10), 4 sex char(2) 5 ); 6 7 insert into p_user(name,sex) values('A',"男&…