1、xml映射文件中,不同的xml映射文件,id是否可以重复
如果配置了namespace,那么id可以重复,
如果没有配置namespace,那么id不能重复。
namespace:接口的全限定名
id:sql的id属性值为接口中方法的名称
2、如何将sql执行结果封装为目标对象并返回的?都有那些映射形式?
编写映射文件或者使用注解@Result
①:当列名和封装查询结果的类的属性名一一对应时,使用resultType
<select id="findAll" resultType="com.itheima.domain.User">
select * from User
</select>
②:当列名和封装查询结果的类的属性名不对应时,使用resultMap
3、当实体类中的属性名和表中的字段名不一样,怎么办?
①:通过在查询sql语句中定义字段名的别名,让字段名的别名和实体类的属性名一致
②:通过映射字段名和实体类属性名的一一对应关系
4、mapper中如何传递多个参数
①:多条件分开写
使用@Param()
注解指定参数名称
②:多条件封装到对象中
而且多条件封装到对象,可以不用写参数类型
5、Spring、SpringMVC、Mybatis整合流程
Spring整合Mybatis
1、jdbc.properties属性文件
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/day38_ssm_db
jdbc.username=root
jdbc.password=root
2、JdbcConfig配置类
public class JdbcConfig {
@Value("${jdbc.driver}")
private String driver;
@Value("${jdbc.url}")
private String url;
@Value("${jdbc.username}")
private String username;
@Value("${jdbc.password}")
private String password;
//配置连接池
@Bean
public DataSource dataSource(){
DruidDataSource dataSource = new DruidDataSource();
dataSource.setDriverClassName(driver);
dataSource.setUrl(url);
dataSource.setUsername(username);
dataSource.setPassword(password);
return dataSource;
}
//Spring事务管理需要的平台事务管理器对象【前期不写,后期补上】
@Bean
public PlatformTransactionManager transactionManager(DataSource dataSource){
DataSourceTransactionManager ds = new DataSourceTransactionManager();
ds.setDataSource(dataSource);
return ds;
}
}
3、MybatisConfig配置类
public class MyBatisConfig {
@Bean
public SqlSessionFactoryBean sqlSessionFactory(DataSource dataSource){
SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();
factoryBean.setDataSource(dataSource);
factoryBean.setTypeAliasesPackage("com.itheima.domain");
return factoryBean;
}
@Bean
public MapperScannerConfigurer mapperScannerConfigurer(){
MapperScannerConfigurer msc = new MapperScannerConfigurer();
msc.setBasePackage("com.itheima.dao");
return msc;
}
}
4、SpirngConfig配置类
@ComponentScan({"com.itheima.service"})
@PropertySource("classpath:jdbc.properties")
@Import({JdbcConfig.class,MyBatisConfig.class})
@EnableTransactionManagement //开启Spring事务管理
public class SpringConfig {
}
Spring整合SpringMVC
1、SpringMvcConfig配置类
@ComponentScan("com.itheima.controller")
@EnableWebMvc
public class SpringMvcConfig {
}
2、ServletConfig配置类,加载SpringMvcConfig和SpringConfig配置类
public class ServletConfig extends AbstractAnnotationConfigDispatcherServletInitializer {
protected Class<?>[] getRootConfigClasses() {
return new Class[]{SpringConfig.class};
}
protected Class<?>[] getServletConfigClasses() {
return new Class[]{SpringMvcConfig.class};
}
protected String[] getServletMappings() {
return new String[]{"/"};
}
}