数据库部分说的比较多,说明数据库是重头戏,实际上在生产环境中数据库发份量也是很大的。目前接触了JDBC(JdbcTemplate)、MyBatis、JPA(ORM),以后还需要了解数据库缓存(memcached)、Redis、数据库连接池等,这个不在入门系列涉及,需要在实际项目中锻炼了。
最早接触数据库就是纯SQL语句查询,在Java里面就是用JDBC,后来慢慢发现太繁琐,咋办呢?封装一个吧,JdbcTemplate就出来了。
后来发现数据库操作绝大部分都是增删改查,可以封装的更彻底,甚至隐藏SQL。
ORM简化了模型和数据表的设计,也隔离了SQL,但是对于复杂点查询、已经习惯了SQL查询的开发人员、对查询性能有高要求的,还是需要SQL,MyBatis介于两者之间,它拥抱SQL,既有部分封装又可以直接操作SQL。
其实想想就知道,这些不同的框架应用的出现是有其原因的,它们在不同的场景下发挥着作用,不必纠结学哪个,适合用哪个就用哪个。
有时候纯SQL查询性能还是最好的,毕竟省略了很多框架层的封装。