首先,Mybatis 是使用 SQL 语句来进行编程,它非常灵活。你可以将 SQL 写在 XML 文件中,这样可以避免和代码或数据库设计产生冲突,也便于集中管理。MyBatis 还提供了 XML 标签,用来编写动态的 SQL 语句,而且可以重复使用。我们可以根据不同情况灵活地生成 SQL。
和使用 JDBC 相比,MyBatis 能减少超过50%的代码,也省去了很多 JDBC 冗余的操作,不需要手动来回打开和关闭数据库连接。减轻了开发负担。
MyBatis 很友好地兼容各种数据库。因为它基于 JDBC 连接数据库,只要是 JDBC 支持的数据库,MyBatis 都能支持。这使得在不同的项目中,甚至在不同类型的数据库之间切换变得非常方便。
另外,MyBatis 还能轻松地与 Spring 框架集成,给项目开发带来了很大的便利。
对于对象和数据库之间的映射,MyBatis 提供了映射标签,让你可以方便地将对象和数据库的字段关系映射起来。此外,对象关系映射标签还支持对象关系组件的维护,这是一个很有用的功能。
然而,也要注意一些缺点。虽然 MyBatis 很强大,但编写 SQL 语句可能会相对繁琐,特别是当涉及多个字段或多个关联表时。这就要求开发人员在 SQL 编写方面有一定的功底。
另一个缺点是,由于 SQL 语句依赖于特定的数据库,如果想要更换数据库,移植性就会受到影响。这意味着不能轻易地更改数据库,可能需要进行一些适应性的修改。