1.MyBatis与MyBatis-Plus的区别?
MyBatis和MyBatis-Plus都是Java语言中非常常用的ORM框架,二者有以下区别:
1.实现方式不同
MyBatis是基于XML或注解方式进行数据库操作的持久化框架,它提供了简单的CRUD操作及动态SQL生成等功能。
而MyBatis-Plus是在MyBatis框架上的封装,通过对于增强简化后的API更加方便地进行开发,并且在性能、效率和易用性上都有一定的优化。
2.功能支持不同
MyBatis-Plus相比于MyBatis提供了很多额外的功能,例如像条件构造器、代码生成器、分页插件、性能分析拦截器等实用的组件,使得开发者可以轻松快速完成业务逻辑的开发。
而MyBatis相对较为原始,需要手写大量的SQL以完成各种功能的实现。
3.编程风格有所差异
MyBatis的编程风格更加传统,需要定义mapper.xml文件并根据传入的参数使用相应的SQL查询语句,需要实现 Mybatis 提供的各种方法;
而MyBatis-Plus具有许多针对CRUD进行的简化方法,通过继承BaseMapper以及使用Lambda表达式,可以让我们像SpringDataJPA类似地使用接口编程方式进行数据库操作。
下面通过代码示例来演示一下MyBatis和MyBatis-Plus的区别:
-
MyBatis的实现
首先在Mybatis中需要配置sql mapper映射文件,如下所示:
<!-- userMapper.xml -->
<mapper namespace="com.demo.dao.UserMapper"><select id="getUserById" parameterType="java.lang.Integer" resultType="com.demo.entity.User">select * from t_user where id=#{id}</select></mapper>
然后通过Mybatis的SqlSession执行相关方法实现数据查询:
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(configuration);
SqlSession sqlSession = sessionFactory.openSession();
User user = sqlSession.selectOne("com.demo.dao.UserMapper.getUserById", 1);
sqlSession.close();
-
MyBatis-Plus的实现
在MyBatis-Plus中则要比上述方式简单得多,并且提供了更加方便的CRUD操作。例如我们可以定义一个接口继承BaseMapper接口并调用其中提供的方法来操作数据库,如下所示:
public interface UserMapper extends BaseMapper<User> {}
以下是从数据库中根据ID查询数据时,可以在Service层直接调用BaseMapper中提供的selectById()方法:
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {@Overridepublic User getUserById(Long id) {return baseMapper.selectById(id);}
}
2.对称加密和非对称加密的区别
在Java中,对称加密和非对称加密是实现数据加密的两种主要方法,它们在安全性、速度和使用场景上有着本质的区别。下面是对这两种加密方法的基本区别的详细解释:
对称加密
1. **密钥使用**:对称加密使用相同的密钥进行加密和解密。这意味着发送方和接收方都必须拥有这个密钥,并且保持密钥的安全性。
2. **速度**:对称加密算法通常比非对称加密算法要快,因为它们使用的算法比较简单,适合对大量数据进行加密。
3. **安全性**:虽然对称加密算法本身可以非常安全,但密钥管理(尤其是密钥的分发和存储)可能会成为安全性的弱点。
4. **常见算法**:AES(高级加密标准)、DES(数据加密标准)、3DES(三重数据加密算法)等。
非对称加密
1. **密钥使用**:非对称加密使用一对密钥,一个是公开密钥(公钥),另一个是私有密钥(私钥)。公钥用于加密数据,而私钥用于解密数据。公钥可以公开,但私钥必须保密。
2. **速度**:非对称加密算法通常比对称加密慢,因为它们使用的算法更复杂,适用于小块数据的加密,如密钥交换、数字签名等。
3. **安全性**:非对称加密提供了更高级别的安全性,尤其是在公钥/私钥的管理和密钥交换方面,因为即使公钥被公开,没有私钥也无法解密数据。
4. **常见算法**:RSA、ECC(椭圆曲线加密)、Diffie-Hellman 密钥交换等。
使用场景
- **对称加密**通常用于加密大量数据的情况,因为它的加密和解密过程更快。
- **非对称加密**通常用于加密小量数据或进行安全密钥交换的场景。例如,在SSL/TLS协议中,非对称加密用于安全地交换对称密钥,然后对称密钥用于加密传输的数据。
在实际应用中,为了同时利用对称加密的高效性和非对称加密的安全性,两者往往会结合使用。例如,非对称加密用于安全地交换对称加密密钥,然后使用对称加密密钥来加密实际的数据传输。这种方法结合了两者的优点,既保证了加密过程的安全性,又提高了加密和解密的效率。
3.MyBatis-Plus关联表查询怎么写
在 MyBatis-Plus 中进行多表关联查询可以通过使用注解 @TableField
和 @TableId
,以及使用 QueryWrapper 或 LambdaQueryWrapper 来实现。
以下是一个示例,假设有两个表 A 和 B,它们之间通过外键关联:
1.实体类定义
@Data
@TableName("table_a")
public class TableA {@TableId("id")private Long id;@TableField("name")private String name;@TableField("b_id")private Long bId;
}
@Data
@TableName("table_b")
public class TableB {@TableId("id")private Long id;@TableField("name")private String name;
}
2.数据库查询
@Service
public class MyService {@Autowiredprivate TableAMapper tableAMapper;public List<TableA> getTableAWithTableB() {QueryWrapper<TableA> queryWrapper = new QueryWrapper<>();queryWrapper.inSql("b_id", "select id from table_b");return tableAMapper.selectList(queryWrapper);}
}
在这个示例中,通过在 TableA 实体类中添加 @TableField("b_id")
注解来映射 A 表中与 B 表关联的字段。然后在 MyService 类中通过 QueryWrapper 来创建查询条件,实现了 A 表和 B 表的联合查询。
当然,具体的多表关联查询方式还取决于你的数据库表结构和业务需求,你可以根据实际情况进行调整和修改。