Mybatis面试题

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[]{"/"};
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值