h2
数据库?<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
server:
# 服务端口
port: 8090
#h2配置
#启用SQL语句的日志记录
spring:
jpa:
show-sql: true
#设置ddl模式
hibernate:
ddl-auto: update
# database-platform: org.hibernate.dialect.H2Dialect
##数据库连接设置
datasource:
driverClassName: org.h2.Driver
#可执行程序的当前路径
url: jdbc:h2:mem:test
#指定的静态配置路径
username: h2
password: h2
##数据初始化设置
#进行该配置后,每次启动程序,程序都会运行resources/db/schema.sql文件,对数据库的结构进行操作。
schema: classpath:db/schema.sql
#进行该配置后,每次启动程序,程序都会运行resources/db/data.sql文件,对数据库的数据操作。
data: classpath:db/data.sql
##h2 web console设置
#表明使用的数据库平台是h2
platform: h2
# 进行该配置后,h2 web consloe就可以在远程访问了。否则只能在本机访问。
h2:
console:
settings:
web-allow-others: true
#进行该配置,你就可以通过YOUR_URL/h2访问h2 web consloe。YOUR_URL是你程序的访问URl。
path: /h2
#进行该配置,程序开启时就会启动h2 web consloe。当然这是默认的,如果你不想在启动程序时启动h2 web consloe,那么就设置为false。
enabled: true
启动H2数据库有两种方式
自动执行.sql
文件,每次重新启动项目是,都会去运行一次操作文件
DROP TABLE IF EXISTS `student`;
CREATE TABLE `student`
(
`id` varchar(225),
`name` varchar(225) ,
`age` int(11)
);
-- ----------------------------
-- Records of student
-- ----------------------------
INSERT INTO `student` VALUES ('0', '张三', 20);
INSERT INTO `student` VALUES ('1', '少杰', 20);
INSERT INTO `student` VALUES ('10', '赵子龙', NULL);
自动去创建数据库,借用Spring Data Jpa
的注解,启动时自动创建内存数据库
@Entity
@Data
@Accessors(chain = true)
@Table(name = "student")
@AllArgsConstructor
@NoArgsConstructor
public class Student implements Serializable {
/**
* 学生id
*/
@Id
@Column(name = "id")
private String id;
/**
* 学生名称
*/
@Column(name = "name")
private String name;
/**
* 学生年纪
*/
@Column(name = "age")
private Integer age;
}
使用配置的账号密码进行登录,别的不说,先跑起来最要紧
(注意:这时对数据库中的数据进行任何的改变都将是无效的,需要对数据做持久化才能保存数据)
修改yaml
配置
# windows本地数据库地址
spring.data.url: jdbc:h2:file:D:/tools/development/h2/db/student
重新启动,发现多了两个文件,分别是student.mv.db
和student.trace.db
操作数据库什么的,都和MySQL
没什么太大的区别,当前用的是Spring Data Jpa
那就更简单了,非常nice