快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

MyBatis数据输入,总体机制的概括

1.MyBatis数据输入

1.1 Mybatis总体机制概括

广河网站制作公司哪家好,找成都创新互联公司!从网页设计、网站建设、微信开发、APP开发、响应式网站设计等网站项目制作,到程序开发,运营维护。成都创新互联公司从2013年开始到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选成都创新互联公司

1.2 概念说明

注意:这里的简单类型不是指的基本数据类型。

1.3 单个简单类型参数

1.3.1 Mapper接口中的抽象方法

publicinterfaceEmpMapper {

/**

* 通过这个方法对应Mapper配置文件中的SQL语句

* @paramempId 当前方法的参数对应SQL语句中#{empId}声明的参数

* @return当前方法的返回值类型和resultType属性指定的类型一致

*/

abstractpublicEmp selectById(long empId);

}

1.3.2 SQL语句

"selectById"resultType="com.hy.bean.Emp">

select emp_id empId,emp_name empName,emp_pwd empPwd,emp_gender empGender , emp_salary empSalary

from sys_emp where emp_id = #{empId}

1.4 复杂类型参数

1.4.1 实体类类型的参数

1)EmpMapper接口中抽象方法声明

abstract public int insert(Emp emp);

2SQL语句

<insert id=”insert”>

insert into sys_emp(emp_name,emp_pwd,emp_gender,emp_salary)

values(#{empName},#{empPwd},#{empGender},#{empSalary})

如果是实体类类型的参数,此时,#{}中的名字就不能随便写了,此时表达式中的名字,就需要和Emp实体类中getXxx方法名,去掉get,然后剩下的单词其首字母小写后的名字相对应。

mybaits会根据#{}表达式中的名字,根据反射机制,找到Emp中的getXxx方法,获取对应的数据。

1.4.2对应关系如图:

1.5 零散的简单类型数据

1.6 Map类型参数

如果零散的简单类型太多了,可以使用Map类型

create table sys_emp(

emp_id bigint auto_increment,

emp_name varchar(20),

emp_pwd varchar(20),

emp_gender enum('m','f'),

emp_salary double(10,5),

primary key(emp_id)

);

INSERT INTO `sys_emp` VALUES (null, '范冰冰', 'fbb', 'f', 100.5);

INSERT INTO `sys_emp` VALUES (null, '李冰冰', 'lbb', 'f', 300);

INSERT INTO `sys_emp` VALUES (null, '张彬彬', 'zbb', 'm', 599);

INSERT INTO `sys_emp` VALUES (null, '万茜', 'wq', 'm', 4000);

INSERT INTO `sys_emp` VALUES (null, '李若彤', 'lrt', 'm', 5000.8);

select * from `sys_emp`;

2.Mybatis数据输出

2.1 返回单个简单类型

2.2 返回自增的主键

使用场景:保存订单Order对象 和 订单明细List。其中,OrderItem对应表t_order_item表,包含一个外键,指向t_order表中的主键。

insertWithKey,注意:返回值还是受影响的行数,它会将插入的主键,返回到传递过来对象指定的属性里面。

2.3返回实体类型

假设我们没有写列的别名,则返回null,因为值无法注入,所以就算查询出来,也没意义,所以mybaits干脆返回一个null给你。

2.3.1 数据库表字段和实体类属性对应

给列的字段起别名

2.3.2 如何自动的进行匹配呢?

数据库表中字段的命名是按照规范来进行设计的emp_name,java类中的属性也是按规范设计的empName,那么每次都写别名感觉很麻烦,该如何处理???

2.4返回Map类型

2.5 返回List类型

2.6 数据库表的字段和实体类属性的对应关系

2.6.1 给表的字段起别名

2.6.2 全局配置自动识别驼峰式命名规则

2.6.3 使用resultMap

使用resultMap标签定义对应关系,再再后面的SQL语句中引用这个对应关系。


名称栏目:MyBatis数据输入,总体机制的概括
网站路径:http://6mz.cn/article/dscgehe.html

其他资讯