当前位置: 首页 > news >正文

win+mac通用的SpringBoot+H2数据库集成过程。

有小部分大学的小部分老师多毛病,喜欢用些晦涩难搞的数据库来折腾学生,我不理解,但大受震撼。按我的理解,这种数据库看着好像本地快速测试代码很舒服,但依赖和数据库限制的很死板,对不上就是用不了,而且创建过程也麻烦,就算能借用mysql模型,也没多方便。

可以先看下面这篇了解下,再看我的避坑:

springboot+H2集成的另一个帖子。

一. 搭建数据库

1.下载H2数据库

点击下载

注意解压后进入 ./h2/bin/h2-2.2.224.jar 看到这个文件,win可以在文件浏览器的搜索框中输入cmd

用执行以下命令,mac则cd到该文件夹执行以下命令,这需要java环境的。注意这时候mac启动好了会直接跳到这个页面,win要手动打开(localhost:8082/login.jsp)

java -jar h2-2.2.224.jar

2.如何进入控制台

注意:最开始数据库没有东西,默认Generic H2 (Embedded),你在url最后写好一个你想写的数据库名后,点击链接会自动创建一个的,但用户名密码你要记住(密码不写也没事)。

3.初始化页面内容。

这里一开始没有你要的表数据,默认的两个表内容不要改,把自己的数据库sql内容放进文本框中,执行完得到 3中的内容。

3.执行数据库并新建表内容。

4.获取数据库db文件。

搞定以上那些,会生成一份数据库文本,格式为:xxx.mv.db。每次新建都会生成一份的。

win可以在数据库安装的地方找,一开始就可以设置路径。

mac到/Users/yourName/xxmall.mv.db可以找到。

---------------------------------------------------------------------------------------------------------

为什么说这么多呢,因为这份(xxmall.mv.db)文件就是用来给项目链接数据库运行的。

二.在idea运行springboot+H2项目。

以我的项目为例,idea中,找个路径放好你的db文件,比如我这样

1.配置文件。

yml还是properties(我是这个)都行配置的重点如下:

#H2  ;MODE= XX h2数据库配置
#spring.datasource.url=jdbc:h2:file:./h2db/xxmall  
# url后用 jdbc:h2:mem:xxmall 这个也可以,但注意,这里是没有数据的,
# 你需要写一份insert脚本先去跑sql,这也是我把(xxmall.mv.db)拆出来的原因。
spring.datasource.url=jdbc:h2:file:./h2db/xxmall;MODE=MySQL
# mode不能漏泄,你可以根据需要写哪个数据库特性
spring.datasource.username=sa
spring.datasource.password=
spring.datasource.driver-class-name=org.h2.Driver
spring.h2.console.settings.web-allow-others=true
spring.h2.console.path=/h2-consolespring.datasource.type=com.alibaba.druid.pool.DruidDataSourcespring.thymeleaf.mode=HTML5
spring.thymeleaf.encoding=UTF-8
spring.thymeleaf.content-type=text/html
spring.thymeleaf.cache=false##################### jpa hibernate 配置 #########################
spring.jpa.show-sql=false
spring.jpa.database=h2
spring.jpa.properties.hibernate.format_sql=false
spring.jpa.generate-ddl=true
spring.jpa.hibernate.ddl-auto=update

2.注意点:

jdbc:h2:file:./h2db/xxmall;MODE=MySQL

/h2db/ 是本项目内的文件夹位置,xxmall是数据库名字,不要带上.mv.db,后面是特性借用mysql。

注意你用的就是H2数据库,不要怀疑,下面的账号密码写你填上去的。

2.还有实体类一定要写清楚@Column(name = "count") name=里面对应的数据库字段,H2对大小写,驼峰都敏感(我用JPA的原因吗?),必须每个都写好写对,还有,绝对不可以带反单引号 `,sql也不要。

最后就是依赖,你下载的H2是哪个版本,那么pom文件就必须用哪个版本。

相关文章:

  • SwiftUI中ContentUnavailableView的使用(iOS 17、tvOS 17推出的新组件)
  • Verilog实现的数字钟
  • 测试记录3:WLS2运行Linux界面
  • 【golang学习之旅】Go中的cron定时任务
  • 扩展 Kafka 集群从三台节点到四台节点的过程
  • C++结合OpenCV进行图像处理与分类
  • 植物大战僵尸杂交版2.0.88最新版安装包
  • 爬虫之反爬思路与解决手段
  • 记录一次jlink连不上cpu的情况
  • 洛谷 CF1969A Two Friends 题解
  • RAG 高效应用指南 :Query 理解
  • Java1.8全套家政上门服务+springboot+ mysql +Thymeleaf 技术架构开发,家政APP系统在线派单,师傅入驻全套商业源码
  • 【TB作品】 51单片机8x8点阵显示滚动汉字仿真
  • html+CSS+js部分基础运用15
  • C# 判断字符串不等于空的示例
  • 0x05 Python数据分析,Anaconda八斩刀
  • Android 初级面试者拾遗(前台界面篇)之 Activity 和 Fragment
  • canvas 绘制双线技巧
  • JAVA SE 6 GC调优笔记
  • Netty 4.1 源代码学习:线程模型
  • 构建工具 - 收藏集 - 掘金
  • 数据结构java版之冒泡排序及优化
  • 网络应用优化——时延与带宽
  • 用Canvas画一棵二叉树
  • AI算硅基生命吗,为什么?
  • ​HTTP与HTTPS:网络通信的安全卫士
  • ​香农与信息论三大定律
  • # AI产品经理的自我修养:既懂用户,更懂技术!
  • # Python csv、xlsx、json、二进制(MP3) 文件读写基本使用
  • # 再次尝试 连接失败_无线WiFi无法连接到网络怎么办【解决方法】
  • #window11设置系统变量#
  • (1)svelte 教程:hello world
  • (aiohttp-asyncio-FFmpeg-Docker-SRS)实现异步摄像头转码服务器
  • (C++17) std算法之执行策略 execution
  • (pytorch进阶之路)CLIP模型 实现图像多模态检索任务
  • (第27天)Oracle 数据泵转换分区表
  • (多级缓存)多级缓存
  • (二) Windows 下 Sublime Text 3 安装离线插件 Anaconda
  • (附源码)spring boot火车票售卖系统 毕业设计 211004
  • (附源码)计算机毕业设计SSM疫情社区管理系统
  • (四)Android布局类型(线性布局LinearLayout)
  • (五) 一起学 Unix 环境高级编程 (APUE) 之 进程环境
  • (转) RFS+AutoItLibrary测试web对话框
  • (转载)Linux 多线程条件变量同步
  • (轉貼) 寄發紅帖基本原則(教育部禮儀司頒布) (雜項)
  • ***微信公众号支付+微信H5支付+微信扫码支付+小程序支付+APP微信支付解决方案总结...
  • .net core IResultFilter 的 OnResultExecuted和OnResultExecuting的区别
  • .NET 事件模型教程(二)
  • .net中的Queue和Stack
  • [ 环境搭建篇 ] 安装 java 环境并配置环境变量(附 JDK1.8 安装包)
  • []利用定点式具实现:文件读取,完成不同进制之间的
  • [14]内置对象
  • [2013AAA]On a fractional nonlinear hyperbolic equation arising from relative theory
  • [2016.7 Day.4] T1 游戏 [正解:二分图 偏解:奇葩贪心+模拟?(不知如何称呼不过居然比std还快)]
  • [20170705]diff比较执行结果的内容.txt