标签:insert dal 抽象 exception before bat 1.4 gets 接口
Example:where后的条件
| 方法 | 功能说明 | 
| int countByExample(XXXExample example) thorws SQLException | 按条件计数 | 
| int deleteByPrimaryKey(Integer id) SQLException | 按主键删除 | 
| int deleteByExample(XXXExample example) thorws SQLException | 按条件删除 | 
| String/Integer insert(XXX record) thorws SQLException | 插入数据 | 
| XXX selectByPrimaryKey(Integer id) thorws SQLException | 按主键查询 | 
| ListselectByExample(XXXExample example) thorws SQLException | 按条件查询 | 
| ListselectByExampleWithBLOGs(XXXExample example) thorws SQLException | 按条件查询(包括BLOB字段)。只有当数据表中的字段类型有为二进制的才会产生。 | 
| int updateByPrimaryKey(XXX record) thorws SQLException | 按主键更新 | 
| int updateByPrimaryKeySelective(XXX record) thorws SQLException | 按主键更新值不为null的字段 | 
| int updateByExample(XXX record, XXXExample example) thorws SQLException | 按条件更新 | 
| int updateByExampleSelective(XXX record, XXXExample example) thorws SQLException | 按条件更新值不为null的字段 | 
注意:
| int updateByExampleSelective(@Param("record") Pets record, @Param("example") PetsExample example); /** * 使用@Param("record") 注解,可以把参数封装成Map<String,Object> * @Param("record") Pets record, @Param("example") 相当于 * * Map<String,Object> map = new HashMap(String,Object); * map.put("record",record); * map.put("example",example); */ | 
上述方法中的@Param注解
mybatis会把参数封装成Map对象,键为注解的参数,值为方法的参数
mybatis的逆向工程中会生成实例及实例对应的example,example用于添加条件,相当where后面的部分 
xxxExample example = new xxxExample(); 
Criteria criteria = example .createCriteria();
| 方法 | 说明 | 
| example.setOrderByClause(“字段名 ASC”); | 添加升序排列条件,DESC为降序 | 
| example.setDistinct(false) | 去除重复,boolean型,true为选择不重复的记录。 | 
| criteria.andXxxIsNull | 添加字段xxx为null的条件 | 
| criteria.andXxxIsNotNull | 添加字段xxx不为null的条件 | 
| criteria.andXxxEqualTo(value) | 添加xxx字段等于value条件 | 
| criteria.andXxxNotEqualTo(value) | 添加xxx字段不等于value条件 | 
| criteria.andXxxGreaterThan(value) | 添加xxx字段大于value条件 | 
| criteria.andXxxGreaterThanOrEqualTo(value) | 添加xxx字段大于等于value条件 | 
| criteria.andXxxLessThan(value) | 添加xxx字段小于value条件 | 
| criteria.andXxxLessThanOrEqualTo(value) | 添加xxx字段小于等于value条件 | 
| criteria.andXxxIn(List<?>) | 添加xxx字段值在List<?>条件 | 
| criteria.andXxxNotIn(List<?>) | 添加xxx字段值不在List<?>条件 | 
| criteria.andXxxLike(“%”+value+”%”) | 添加xxx字段值为value的模糊查询条件 | 
| criteria.andXxxNotLike(“%”+value+”%”) | 添加xxx字段值不为value的模糊查询条件 | 
| criteria.andXxxBetween(value1,value2) | 添加xxx字段值在value1和value2之间条件 | 
| criteria.andXxxNotBetween(value1,value2) | 添加xxx字段值不在value1和value2之间条件 | 
1. pom.xml文件中添加分页插件
| <!-- https://mvnrepository.com/artifact/com.github.pagehelper/pagehelper --> <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>4.1.6</version> </dependency> | 
2. 在mybatis配置文件中添加分页插件
| <plugins> <plugin interceptor="com.github.pagehelper.PageHelper"> <property name="dialect" value="mysql"/> </plugin> <!--5.0版本pagehelper--> <!-- <plugin interceptor="com.github.pagehelper.PageInterceptor"> <property name="helperDialect" value="mysql"/> </plugin> --> </plugins> | 
3. 测试类中使用PageHelper分页查询
| PageHelper.startPage(2, 4); List<Pets> list1 = mapper.selectByExample(null); PageInfo<Pets> pageInfo = new PageInfo<Pets>(list1); System.out.println(list1); List<Pets> list2 = pageInfo.getList(); System.out.println(list2); for (Pets pets : list2) { System.out.println(pets); } | 
| public interface PetsMapper { 
 @Select(value="select id,name,birth_date birthDate,type_id typeId, owner_id ownerId from pets") public List<Pets> findAll(); 
 @Select("select id,name,birth_date birthDate,type_id typeId, owner_id ownerId from pets where id=#{id}") public Pets findById(int id); 
 @Insert("insert into pets(name,birth_date,type_id,owner_id) values(#{name},#{birthDate},#{typeId},#{ownerId})") @SelectKey(keyColumn="id",keyProperty="id",resultType=Integer.class, before = false, statement = { "select last_insert_id()" }) public int insert(Pets p); 
 @Update(value="update pets set name=#{name},birth_date=#{birthDate} where id=#{id}") public int update(Pets p); 
 @Delete("delete from pets where id=#{id}") public int delete(int id) ; 
 } | 
场景:当字段类型和数据库类型不一致时,需要自定义类型转化器。
使用:
1)编写一个普通类继承BaseTypeHandler<T>抽象类,或者实现TypeHandler<T>接口。重写三个方法:如下:
| /** *TODO自定义类型处理器 * 遇到Address类型的字段,会自动来调用该类中的方法 * 1)新增 修改 :Address对象--->String 调用setNonNullParameter() 方法 处理address类型的字段 * 2)查询: 把varchar类型的address--->Address类型 * 调用getNullableResult/getNullableResult * 把数据库的address 重新封装成Address类型 */ public class MyAddressTypeHandler extends BaseTypeHandler<Address> { 
 /** * 新增 或者修改时 遇到Address 类型的字段 自动会调用该方法 */ @Override public void setNonNullParameter(PreparedStatement ps, int i, Address parameter, JdbcType jdbcType) throws SQLException { //填充address这个字段的占位符 ps.setString(i, parameter.toString());//对象--->字符串 } /** * 根据列名查询 */ @Override public Address getNullableResult(ResultSet rs, String columnName) throws SQLException { // TODO Auto-generated method stub String a = rs.getString(columnName); //山东省-青岛市-市北区-市北路-100(String) Address address = null; if (a!=null) { String s [] = a.split("-"); address = new Address(); address.setProvinceName(s[0]); address.setCityName(s[1]); address.setDistinctName(s[2]); address.setStreetName(s[3]); address.setNo(Integer.parseInt(s[4].trim())); } return address; } /** * 根据下标查询 */ @Override public Address getNullableResult(ResultSet rs, int columnIndex) throws SQLException { String a = rs.getString(columnIndex); //山东省-青岛市-市北区-市北路-100(String) Address address = null; if (a!=null) { String s [] = a.split("-"); address = new Address(); address.setProvinceName(s[0]); address.setCityName(s[1]); address.setDistinctName(s[2]); address.setStreetName(s[3]); address.setNo(Integer.parseInt(s[4].trim())); } return address; } 
 /** * 存储过程 */ @Override public Address getNullableResult(CallableStatement cs, int columnIndex) throws SQLException { // TODO Auto-generated method stub return null; } | 
2)在mybatis的配置文件中配置该处理器
| <!-- 自定义类型处理器 --> <typeHandlers> <!-- 配置自定义类型处理器 配置完成后:遇到address类型的字段 自动会调用MyAddressTypeHandler类处理该字段 --> <typeHandler handler="com.itqf.handler.MyAddressTypeHandler"/> </typeHandlers> | 
#{}
按照该字段真实的值的类型填充占位符。例如:String类型,调用ps.setString()填充。
${}
直接把值拼接到sql语句中,不拼接链接符号。
存在sql注入的问题
应用场景:排序时,要排序的字段,排序规则,就可以使用${}
| 排序: select * from users order by #{order} #{sorter}; 使用#{}方式,执行sql语句 select * from users order by ‘id‘ ‘desc‘; 
 select * from users order by ${order} ${sorter}; 使用${}方式,执行sql语句 select * from users order by id desc; | 
标签:insert dal 抽象 exception before bat 1.4 gets 接口
原文地址:https://www.cnblogs.com/wanghuaying/p/9714378.html