- 授权协议: Apache
- 开发语言: Java
- 操作系统: 跨平台
- 软件首页: http://git.oschina.net/jrl/mybatis-mapper
- 软件文档: http://git.oschina.net/jrl/mybatis-mapper
软件介绍
Mybatis-mapper
Mapper 继承 CrudMapper 后,无需编写 mapper.xml 文件,即可获得 CRUD 功能
MyBatis 的 sql 默认加载规则
MyBatis通过xml、SqlProvider两种方式获取sql,xml的优先级高于SqlProvider,且xml、SqlProvider中的sql不允许出现同名
mapper 调整后的 sql 加载规则
sql的优先级:xml > SqlProvider > crudsql
xml、SqlProvider、crudsql允许出现同名的sql,优先级高的有效
约定规则
实体类类名驼峰转下划线即为数据库表名,如类User、UserGroups对应的数据库表名为user、user_groups
实体类属性名默认与数据库表字段名一一对应,忽略transient修饰的属性
实体类属性id(Long、long、Integer、int类型)默认对应数据库表主键;如果使用了其他的属性名或主键策略,可以使用注解@PK进行标识
既没采用默认id作为主键,也没使用@PK标识主键,则认为数据库表没有单一主键;根据主键操作的删除、修改、查找方法不会被注入
测试用例
public class UserMapperTest {
public static void main(String[] args) {
String resource = "mybatis.xml";
InputStream in = UserMapperTest.class.getClassLoader().getResourceAsStream(resource);
// 此处采用MybatisSessionFactoryBuilder构建SqlSessionFactory,目的是引入CrudMapper功能
SqlSessionFactory sessionFactory = new MybatisSessionFactoryBuilder().build(in);
SqlSession session = sessionFactory.openSession();
UserMapper userMapper = session.getMapper(UserMapper.class);
// 此处的selectByPK被UserMapper.xml中的selectByPK覆盖了
User user = userMapper.selectByPK(2);
System.out.println(user);
user.setName("update_" + user.getName());
// updateByPK是从CrudMapper中继承而来的,UserMapper.xml中并没有申明该sql
userMapper.updateByPK(user);
// 此处的selectByPK被UserMapper.xml中的selectByPK覆盖了
user = userMapper.selectByPK(user.getPk());
System.out.println(user);
session.commit();
}
}
断点:互联网进化启示录
[美]杰夫·斯蒂贝尔 / 师蓉 / 中国人民大学出版社有限公司 / 2014-11-1 / CNY 49.00
一部神经学、生物学与互联网技术大融合的互联网进化史诗巨著。 我们正置身网络革命中。互联网的每一丝变化都与你我息息相关。当科技变得无处不在时,它就会改变你我。在《断点》一书中,大脑科学家和企业家杰夫·斯蒂贝尔将带领读者来到大脑、生物与技术的交汇处,向读者展示生物学和神经学是如何与互联网技术发生联系的;我们是如何通过生物学上的前车之鉴,来预测互联网的发展的;互联网在经历增长、断点和平衡后又会发生......一起来看看 《断点:互联网进化启示录》 这本书的介绍吧!
