最近使用嵌入式数据库h2遇到了诸多麻烦,上网查大部分的资料都是片面没有一站式的解决。为此就是我发这篇博客的初衷,我将根据我的项目来说明怎么使用h2数据库
1:第一步h2数据库相关依赖
spring-boot版本2.x就行,dpring-boot 3.x版本用的是jakarta而H2数据库用的是javax
<!-- 嵌入式数据库 -->
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<scope>runtime</scope>
</dependency>
<!-- jdbc -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
2:数据库连接以及相关的配置
我的H2是本地文件模式数据库没有用内存模式,下面必须仔细看
spring:
#数据库配置
datasource:
driver-class-name: org.h2.Driver
username: root #名字随便,因为这个数据库是需要初始化的
password: root #密码随便
#file:表示用的本地文件模式 ./h2DB:的意思就是在路径项目创建数据库文件 FILE_LOCK=SOCKET:这个建议带上,h2默认默认是给数据库文件加锁的,这个机制就是哪个连接使用了数据库文件就产生一个 xxx.lock.db的文件,其他的在访问就会报错,假如用idea连接也需要加上这个语句,看如下图
url: jdbc:h2:file:./h2DB;FILE_LOCK=SOCKET
h2:
console:
enabled: true
path: /h2
settings:
web-admin-password: root
h2数据库文件生成位置
IDEA连接h2数据库
3:增删改查注意点
前面如果没问题的话这里也需要注意,h2数据库跟传统的mysql语法有的细节不一致
1.1、删除数据库
mysql drop database xxx
h2 drop schema xx;
1.2、创建数据库
mysql create database xxx
h2 create schema xx;
1.3、使用数据库
mysql use database xxx
h2 set schema xxx
1.4、插入
这里吐槽一下,如果你的sql语法跟h2的sql语法不一致,它会报异常,但这个异常就让人非常难受他的提示非常不到位,如下
mysql insert into xxx() value/values() mysql是value和values都可以
h2 insert into xxx() value() h2只能是values,就以为少了一个’s‘浪费了我大量时间,所以如果你遇见h2提示你语法错误,就上网查查h2相关的sql语法,在检查其他问题
4:整合mybatis
这个和mysql整合没什么区别就是注意:
5:使用sql脚本
语法如下,如果是idea使用可能有错误提示,不用理会运行就行,还有就是sql脚本文件的位置
RUNSCRIPT FROM 'src/main/resources/sql/SQLScript.sql'
SQL脚本的位置,这个也好解决,右键点击脚本文件选择’复制路径/引用‘
SCRIPT FROM 'src/main/resources/sql/SQLScript.sql'