Mybatis 别名机制,自动扫描 数据的增删改
2024-09-08 02:32:41
mybatis别名机制:
在mybatis.xml文件中的<configuration></configuration>标签中间加入属性<typeAliases></typeAliases>
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 类型别名 -->
<typeAliases>
<!-- <typeAlias type="com.maya.model.TUser" alias="test"/> --><!-- 别名 -->
<package name="com.maya.model" /> <!-- 有点像spring中的那个扫描器 -->
</typeAliases> <environments default="test1">
<environment id="test1">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="oracle.jdbc.driver.OracleDriver"/>
<property name="url" value="jdbc:oracle:thin:@localhost:1521:orcl"/>
<property name="username" value="zhao"/>
<property name="password" value="123"/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/maya/dao/TUserMapper.xml"/>
</mappers> </configuration>
此时,在TUserMapper.xml文件中,将resultType改一下
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.maya.dao.TUserMapper"><!-- 一般的命名规则,包名开始,到对应的配置文件结束 --> <!-- <select id="List" resultType="com.maya.model.TUser" >--> <!-- 原来的的样式 -->
<!-- <select id="List" resultType="test" > --> <!-- 用别名的方式 -->
<select id="List" resultType="tUser"> <!-- 扫描的方式,命名规则:对应的类的名,首字母小写 -->
select * from t_user
</select>
</mapper>
经测试,依然可以执行
假设数据库中的列名与实体类中的数据类型对应不起来,那么需要在配置文件中加入如下代码
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.maya.dao.TUserMapper"> <!-- 需要加的部分 -->
<resultMap type="tUser" id="user">
<result property="username1" column="username" jdbcType="number" javaType="int"/>
<!--property是实体类中的属性,column是数据库中的字段 jdbctype 数据库中的字段类型 -->
</resultMap> <select id="List" resultType="tUser">
select * from t_user
</select>
</mapper>
增删改:
添加:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.maya.dao.TUserMapper"> <insert id="add" parameterType="TUser"> <!--传过来的实体类 -->
insert into t_user values(#{id},#{userName},#{password})<!--sql语句,里面对应着实体类的值,这里是#{} 不是el表达式 -->
</insert>
</mapper>
junit测试
@Test
public void insert(){
TUser tu=new TUser();
tu.setId(1);
tu.setUserName("赵六");
tu.setPassword("123456");
int s=ss.insert("com.maya.dao.TUserMapper.add", tu);
System.out.println(s);
}
打印结果如下:
数据库中的结果如下
删除:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.maya.dao.TUserMapper">
<delete id="delete" parameterType="int">
delete t_user where id=#{id}
</delete>
</mapper>
junit测试:
@Test
public void delete(){
int s=ss.insert("com.maya.dao.TUserMapper.delete", 1);
System.out.println(s);
}
数据库中id为1的数据已经没了
改:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.maya.dao.TUserMapper">
<update id="update" parameterType="tUser">
update t_user set username=#{userName},password=#{password} where id=#{id}
</update>
</mapper>
junit测试
@Test
public void update(){
TUser tu=new TUser();
tu.setId(4);
tu.setUserName("赵六");
tu.setPassword("123456");
ss.update("com.maya.dao.TUserMapper.update", tu);
}
十分抱歉,最后这个应该是没错的,电脑上的数据库突然崩了,没法查看 但是我感觉应该是没有错了的
最新文章
- OpenGL帧缓存对象(FBO:Frame Buffer Object)(转载)
- mysql优化一 之 优化内容概述及开启慢查日志的相关配置
- SSH的各个配置文件:
- 解决windows系统80端口被占用问题(转)
- 【分享】分享一个压缩 PNG 的网站 TinyPNG
- nginx禁止目录php执行权限
- Pison geeker
- CefSharp使用入门
- Angular(02)-- Angular-CLI命令
- 在windows系统下安装linux虚拟机(VMware)
- Angular6 用户自定义标签开发
- scala转换date提取年月日时分秒
- Python minidom模块(DOM写入和解析XML)
- GO | KEGG的注释是怎么来的?
- MT【227】换钱的总数
- Android中应用contentprovider来创建数据库的一些步骤
- Python3中的编码问题
- ps -aux与ps -ef
- 【xsy1147】 异或(xor) 可持久化trie
- 洛谷P1345 [USACO5.4]奶牛的电信 [最小割]