加强网站建设会,wordpress 手机端浮动,微信公众平台推广方案,广州网站建设推荐使用XML配置文件实现数据库操作#xff08;一#xff09;
1.SQL映射文件
SQL映射文件就是我们通常说的mapper.xml配置文件#xff0c;主要实现SQL语句的配置和映射#xff0c;同时实现Java的POJO对象与数据库中的表和字段进行映射关联的功能。
1.1 mapper.xml的结构
下…使用XML配置文件实现数据库操作一
1.SQL映射文件
SQL映射文件就是我们通常说的mapper.xml配置文件主要实现SQL语句的配置和映射同时实现Java的POJO对象与数据库中的表和字段进行映射关联的功能。
1.1 mapper.xml的结构
下面就来详细介绍mapper.xml文件的结构。首先看一个完整的mapper.xml示例
?xml version1.0 encodingUTF-8?
!DOCTYPE mapper PUBLIC -//mybatis.org//DTD Mapper 3.0//ENhttp://mybatis.org/dtd/mybatis-3-mapper.dtd
mapper namespacecom.example.demo.Mapper.StudentMapperselect idselectAll resultMapBaseResultMapSELECT*FROM student/selectresultMap idBaseResultMap typecom.example.demo.model.Studentid columnid propertyid jdbcTypeBIGINT /result columnname propertyname jdbcTypeVARCHAR /result columnsex propertysex javaTypeINTEGER /result columnage propertyage jdbcTypeINTEGER //resultMap
/mapper如上述示例所示一般mapper.xml主要分为4部分
1mapper.xml的语法声明声明MyBatis语法。
2通过namespace指明mapper.xml文件对应的Mapper接口。
3通过XML标签定义接口方法对应的SQL语句id属性对应Mapper接口中的方法resultMap属性为返回值类型。
4resultMap标签定义返回的结果类型与数据库表结构的对应关系上面映射的是Student实体类对象。
1.2 mapper.xml的标签
mapper.xml映射文件提供了一些非常实用的标签其中比较常用的有resultMap、sql、insert、update、delete、select等标签。熟练掌握标签的使用这样使用MyBatis才能如鱼得水。MyBatis标签和功能说明如表所示。 2.定义SQL语句
MyBatis提供了insert、update、delete和delete四个标签来定义SQL语句。接下来就从SQL语句开始介绍每个标签的用法。
2.1 select
select是MyBatis常用的元素之一MyBatis在查询和结果映射中做了相当多的改进。一个简单查询的select元素是非常简单的比如
select idselectOne resultTypehashmap parameterTypeLongSELECT name,age FROM student WHERE id #{id}
/select在上面的示例中通过id查询学生的姓名和年龄。定义方法名为selectOne接收一个Long类型的参数并返回一个HashMap类型的对象。HashMap的键是列名值是结果集中的对应值。#{id}为传入的参数符号。
select标签允许配置很多属性来配置每条语句的行为细节比如参数类型、返回值类型等包含的属性如表所示。
属性说明id命名空间中唯一的标识符被用来引用这条语句parameterType将传入语句的参数的数据类型可选。因为 MyBatis 可以通过类型处理程序(TypeHandler)推断出传入语句的参数的数据类型默认值为未设置 (unset)resultType返回结果的数据类型。注意如果返回的是集合那么应该设置为集合包含的类型而不是集合本身的类型。resultType 和 resultMap 之间只能使用一个resultMap结果映射 resultMap 是 MyBatis 的强大特性之一 resultType 和resultMap 之间只能使用一个flushCache是否清空缓存Select 语句默认值为 false如果设置为 true只要语句被调用将清空本地缓存和二级缓存useCache是否使用缓存默认值为 tue缓存本条语句的查询结果timeout超时时间等待数据库返回请求结果的时间。默认值为未设置 (unset)fetchSize设置返回的结果行数。默认值为未设置 (unset)statementType使用 Statement、PreparedStatement或CallableStatement执行SQL 语句,默认值为PREPAREDresultSetTypeFORWARD_ONLY、SCROLL_SENSITIVE、SCROLL_INSENSITIVE 或 DEFAULT (等价于unset)默认值为DEFAULTdatabaseId数据库厂商标识 (databaseldProvider)如果配置了此属性MyBatis 会加载所有不带databaseId 或匹配当前 databaseId 的语句resultOrdered针对嵌套结果 select 语句默认值为 false如果为 true将会假设包含嵌套结果集或分组,当返回一个主结果行时不会产生对前面结果集的引用resultSets仅适用于多结果集的情况。将列出语句执行后返回的结果集并赋予每个结果集一个名称多个名称之间以逗号分隔
select标签虽然有很多属性但是常用的是id、parameterType、resultType、resultMap这4个属性。需要注意的是resultMap是MyBatis的强大特性之一如果对其理解透彻许多复杂的映射问题都能迎刃而解。
2.2 insert
insert标签主要用于定义插入数据的SQL语句例如
insert idinsert parameterTypecom.example.demo.Mapper.StudentINSERT INTOstudent(id, name, sex, age)VALUES(#{id}, #{name}, #{sex}, #{age})
/insert在上面的示例中插入语句的配置规则更加复杂同时提供了额外的属性和子元素用来处理主键的生成方式。
如果数据库包含自动生成主键的字段那么可以设置useGeneratedKeys“true”然后把keyProperty设置为目标属性。比如上面的Student表已经在id列上使用了自动生成主键那么语句可以修改为
insert idinsert useGeneratedKeystrue keyPropertyid parameterTypecom.example.demo.model.StudentINSERT INTOstudent(name, sex, age)VALUES(#{name}, #{sex}, #{age})
/insert在上面的示例中设置useGeneratedKeys“true”然后设置keyPropertyid对应的主键字段。
insert标签包含的属性如表所示。
属性说明id命名空间中唯一的标识符被用来引用这条语句parameterType将传入语句的参数的数据类型可选。MyBatis 可以通过类型处理程序 (TypeHandler)推断出传入语句的参数的数据类型默认值为未设置 (unset)flushCache是否清空缓存默认值为 true只要语句被调用就清空本地缓存和二级缓存timeout超时时间即等待数据库返回请求结果的时间。默认值为未设置 (unset)statementType使用 Statement、PreparedStatement 或 CallableStatement 执行 SQL 语句默认值为PREPAREDuseGeneratedKeys自动生成主键默认值为 false设置为 true 时根据规则自动生成主键keyProperty指定能够唯一识别对象的属性keyColumn指定数据库表的主键列名databaseld数据库厂商标识 (databaseIdProvider)如果配置了此属性MyBatis 会加载所有不带databaseId 或匹配当前 databaseId 的语句
常用的属性有id、parameterType、useGeneratedKeys、keyProperty等部分属性和select标签是一致的。
2.3 update
update标签和insert标签类似主要用来映射更新语句示例代码如下
update idupdate parameterTypecom.example.demo.model.StudentUPDATEstudentSETname #{name},sex #{sex},age #{age}WHEREid #{iid
/update如果需要根据传入的参数来动态判断是否进行修改可以使用if标签动态生成SQL语句示例代码如下
update idupdate parameterTypecom.example.demo.model.StudentUPDATEstudentSETif testname ! nullname #{name},/ifif testsex ! nullsex #{sex},/ifage #{age}WHEREid #{iid
/update在上面的示例中通过if标签判断传入的name参数是否为空实现根据参数动态生成SQL语句。
update标签包含的属性和insert标签基本一致。
2.4 delete
delete标签用来映射删除语句。
delete iddelete parameterTypeLongDELETE FROMstudentWHEREid #{id}
/deletedelete标签包含的属性如表所示。 delete标签除了少了useGeneratedKeys、keyProperty和keyColumn三个属性之外其余的和insert、update标签一样。
3.结果映射
结果映射是MyBatis重要的功能之一。对于简单的SQL查询使用resultType属性自动将结果转换成Java数据类型。不过如果是复杂的语句则使用resultMap映射将查询结果转换为数据实体关系。
3.1 resultType
前面介绍select标签的时候提到select标签的返回结果可以使用resultMap和resultType两个属性指定映射结构。下面就来演示resultType的用法。
select idselectOne resultTypecom.example.demo.model.Studentselect *from studentwhere id #{id}
/select通过设置resultType属性MyBatis会自动把查询结果集转换为Student实体对象。当然如果只查询部分字段则可以返回HashMap比如
select idselectOne parameterTypeLong resultTypehashmapselect name,age from student where id #{id}
/select上述语句Mybatis会自动将所有的列映射成HashMap对象
3.2 resultMap
在日常开发过程中在大部分情况下resultType就能满足。但是使用resultType需要数据库字段和属性字段名称一致否则就得使用别名这样就使得SQL语句变得复杂。
所以MyBatis提供了resultMap标签定义SQL查询结果字段与实体属性的映射关系。下面演示resultMap的使用。
首先定义resultMap
resultMap idBaseResultMap typecom.example.demo.model.Studentid columnid propertyid jdbcTypeBIGINT /result columnname propertyname jdbcTypeVARCHAR /result columnsex propertysex javaTypeINTEGER /result columnage propertyage jdbcTypeINTEGER /
/resultMap在上面的示例中我们使用resultMap标签定义了BaseResultMap映射关系将数据库中的字段映射为Student实体对象。
然后在SQL语句中使用自定义的BaseResultMap映射关系设置select标签的resultMap“BaseResultMap”示例代码如下
select idselectOne parameterTypeLong resultMapBaseResultMapSELECT*FROM studentWHERE id #{id}
/select3.3 resultMap的结构
resultMap标签的结构比较复杂包含很多子属性和子标签。resultMap标签包含id和type属性
id定义该resultMap的唯一标识。type为返回值的类名。
同样resultMap还可以包含多个子标签包括
1id标签用于设置主键字段与领域模型属性的映射关系此处主键为id对应数据库字段中的主键ID。
2result标签用于设置普通字段与领域模型的属性映射关系。
3association标签用于配置一对一结果映射可以关联resultMap中的定义或者对其他结果映射的引用。
4collection标签用于配置一对多结果映射可以关联resultMap中的定义或者对其他结果映射的引用。
下面是完整的resultMap元素的结构
resultMap idBaseResultMap typecom.example.demo.model.Studentid columnid propertyid jdbcTypeBIGINT /result columnname propertyname jdbcTypeVARCHAR /result columnsex propertysex javaTypeINTEGER /result columnage propertyage jdbcTypeINTEGER /association propertyclasses javaTypecom.example.demo.model.Classesid columnid propertyid/result columnclass_name propertyname jdbcTypeVARCHAR/result columnmemo propertymemo jdbcTypeVARCHAR//association
/resultMap