在平时的开发中,连接数据库进行增删改查的方案有很多,常见的直接有:
-
jdbc,但是如果直接使用jdbc,会存在很多问题。首先,频繁的创建连接和释放会造成资源的浪费从而影响性能,这个问题可以用数据库连接池来解决。而且,还有一种情况比较坑,就是在开发中,有时新手在开发中会忘记close掉connection,造成连接数不够,无法访问数据库。一般企业开发中,如果使用jdbc,也不会直接手写,而是开发一个访问数据库连接的对象,比如DBACCESS之类的,在这个类里面进行连接进行创建和关闭,这样就不会踩到这个坑了。第二,sql会直接写在代码里面,导致的结果是如果我们想要只想要改变下查询的条件或者数据库表结构变化,需要我们重新编写sql语句,那么我们只能修改代码,维护起来就不是很方便。如果不嵌在代码里,而是用一个配置文件来保存sql,那么事情就变得简单起来了。
-
JdbcTemplate。这是spring自带的数据库操作持久层框架。目前不是很熟悉这块,等有机会会好好看。等填坑。。。
-
JPA
-
Mybatis。Mybatis最近在创建springboot项目,整合Mybatis时,遇到了一些常见的问题,不过在网上没找到答案,自己把问题列出来,从而在以后的开发中,能够避免这一块。
项目目录结构:
mapper接口在com.example.demo.mapper目录下。正常情况下,mapper.xml文件是可以直接放在和XXXmapper.java接口同包下的,这样spring可以自动扫描到,这是不需要我们再在application.properties里配置mybatis.mapper-locations=classpath:mappers/*.xml之类的。但是对于这种情况,我们在在使用maven打包时,会自动过滤掉除了java之类的其他文件,这个时候,我们可以在pom.xml文件里面配置
<build>
<!-- 打包时不要忽略xml文件 -->
<resources>
<resource>
<directory>src/main/java</directory>
<includes>