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[]{"/"};
    }
}

相关推荐

  1. 面试(三)mybatis

    2024-03-27 22:34:02       33 阅读
  2. Mybatis学习&面试

    2024-03-27 22:34:02       17 阅读
  3. MyBatis 面试(八)

    2024-03-27 22:34:02       14 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-27 22:34:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-27 22:34:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-27 22:34:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-27 22:34:02       20 阅读

热门阅读

  1. 动态规划——买卖股票C++

    2024-03-27 22:34:02       18 阅读
  2. 深度学习(23):SmoothL1Loss损失函数

    2024-03-27 22:34:02       15 阅读
  3. 使用GO语言验证证书的有效期

    2024-03-27 22:34:02       18 阅读
  4. 免费身份证实名认证接口|PHP开发示例调用

    2024-03-27 22:34:02       19 阅读
  5. 【学不动系列】lint-staged 使用教程

    2024-03-27 22:34:02       19 阅读
  6. 【vivado】在原有工程上新建工程

    2024-03-27 22:34:02       18 阅读
  7. 【GameFramework框架内置模块】17、声音(Sound)

    2024-03-27 22:34:02       21 阅读
  8. FunASR 框架使用;api服务搭建

    2024-03-27 22:34:02       16 阅读
  9. vue中el-tree默认选中节点问题

    2024-03-27 22:34:02       18 阅读
  10. Python自动连接SSH

    2024-03-27 22:34:02       18 阅读