MyBatis入门之增删改查+数据库字段和实体字段不一致问题处理方法

2025-05-29 0 81

数据库字段和实体bean中属性不一致时

之前数据库Person名字字段是name,PersonBean中属性也是name,但是之后数据库中修改为了user_name,

方法1:通过sql语句的字段起别名,别名和实体中的对象属性一致

?

1

2

3

4
SELECT id,user_name as name,sex,age from person

<select id="find" resultType="com.luogg.domain.Person">

SELECT id,user_name as name,sex,age from person

</select>

方法2: mybatis最强大的地方 : reslutMap对象

添加一个中介reslutMap标签,并将select标签中的resultType改为resultMap,并对应resultMap标签的id.

结果集:resultType 基础类型,int,string,Person,

resultMap 针对中介标签resultMap而存在.

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20
<!--配置命名空间,命名空间+ .id 是唯一的sql语句标示符-->

<mapper namespace="com.luogg.mapper.PersonMapper">

<!--中介,当数据库字段和实体bean对象属性不一致时,做一个对应关系-->

<resultMap id="personRM" type="com.luogg.domain.Person">

<!--主键映射-->

<id property="id" column="ID"></id>

<!--普通字段,property指实体属性,column结果集的字段名称,一致的字段可以不写-->

<result property="name" column="USER_NAME"></result>

</resultMap>

<!--查询所有数据,参数有id,resultType结果集,parameterType参数-->

<!--注意 : sql语句中如果有要填写集合的,比如查询所有数据,返回一个Person的结果集,那么resultType参数直接写 路径+集合的类型

比如: 返回一个Person集合,那么就填写Person Bean所在的路径+Person-->

<select id="find" resultMap="personRM">

SELECT * from person

</select>

<!--通过ID查询数据,当有查询条件时,需要写parameterType,返回结果集仍然是Person, #{id}或者${id}都可以-->

<select id="selById" parameterType="int" resultType="com.luogg.domain.Person">

SELECT * FROM person WHERE id = #{id}

</select>

</mapper>

mybatis增删改查

新增人员信息

首先在PersonMapper.xml中添加insert标签,我们的数据库字段user_name,Person实体属性为name,不一致,区别开来.然后在TestMybatis中写入代码.

?

1

2

3

4
<!--添加人员-->

<insert id="insert" parameterType="com.luogg.domain.Person">

INSERT INTO person(id,user_name,age,sex) VALUES(#{id},#{name},#{age},#{sex})

</insert>

package test;

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61
import com.luogg.domain.Person;

import org.apache.ibatis.io.Resources;

import org.apache.ibatis.session.SqlSession;

import org.apache.ibatis.session.SqlSessionFactory;

import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import org.junit.Before;

import org.junit.Test;

import java.io.IOException;

import java.io.InputStream;

import java.util.List;

/**

* Created by luogg on 2017/2/17.

*/

public class TestMybatis {

//SqlSessionFactory为线程安全的

private SqlSessionFactory factory;

@Before

public void init() throws IOException {

String resource = "sqlMapConfig.xml";

InputStream is = Resources.getResourceAsStream(resource);

factory = new SqlSessionFactoryBuilder().build(is);

}

@Test //查询所有

public void findAll() throws IOException {

/**

* 测试数据库的连接

* 1.定义一个String类型的变量resource,指向刚才配置的连接数据库的xml文件

* 2.创建一个输入流,来读取我们的数据库配置文件

* 3.输入流创建工厂.

* 4.有了工厂之后open工厂

* 5.通过session访问配置文件中的sql语句

*/

SqlSession session = factory.openSession();

//如何访问PersonMapper.xml中的sql语句呢? 命名空间+ .id

List<Person> list = session.selectList("com.luogg.mapper.PersonMapper.find");

System.out.println(list.size());

for(Person p : list){

System.out.println(p);

}

}

@Test //通过ID查询人员信息

public void selById(){

SqlSession session = factory.openSession();

Person p = session.selectOne("com.luogg.mapper.PersonMapper.selById",1);

System.out.println(p);

}

@Test //添加人员信息

public void add(){

SqlSession session = factory.openSession();

Person p = new Person();

p.setId(4);

p.setName("luogg");

p.setAge(22);

p.setSex(1);

int i = session.insert("com.luogg.mapper.PersonMapper.insert",p);

session.commit();

if(i==1){

System.out.print("添加人员成功");

}

}

}

修改人员信息 , 查询总的记录条数

prsonMapper.xml文件

?

1

2

3

4

5

6

7

8
<!--修改成员信息-->

<update id="update" parameterType="com.luogg.domain.Person">

UPDATE person SET user_name=#{name},age=#{age} WHERE id=#{id}

</update>

<!--查询总的记录-->

<select id="count" resultType="int">

SELECT COUNT(*) FROM person

</select>

TestMybatis.java文件

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20
@Test //修改人员信息

public void updatePer(){

SqlSession session = factory.openSession();

Person p = new Person();

p.setId(4);

p.setName("luoggg");

//p.setSex(1);

p.setAge(23);

int i = session.update("com.luogg.mapper.PersonMapper.update",p);

session.commit();

if(i==1){

System.out.print("修改信息成功");

}

}

@Test //查询总的记录条数

public void selCount(){

SqlSession session = factory.openSession();

int i = session.selectOne("com.luogg.mapper.PersonMapper.count");

System.out.println(i);

}

条件查询

根据条件查询

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18
<!--带条件查询-->

<select id="selByL" parameterType="map" resultMap="personRM">

SELECT <include refid="cols"/> FROM person

where user_name like #{name}

AND sex=#{sex}

</select>

@Test //带条 件查询

public void selByL(){

SqlSession session = factory.openSession();

Map<String,Object> map = new HashMap<String, Object>();

map.put("name","luo%");

map.put("sex",1);

List<Person> list = session.selectList("com.luogg.mapper.PersonMapper.selByL",map);

System.out.println(list.size());

for(Person p : list){

System.out.println(p);

}

}

MyBatis入门之增删改查+数据库字段和实体字段不一致问题处理方法

以上所述是小编给大家介绍的MyBatis入门之增删改查+数据库字段和实体字段不一致问题处理方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

原文链接:http://www.cnblogs.com/luogg/archive/2017/05/06/6815882.html

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 MyBatis入门之增删改查+数据库字段和实体字段不一致问题处理方法 https://www.kuaiidc.com/116747.html

相关文章

发表评论
暂无评论