H2是Thomas Mueller提供的一个开源的、纯java实现的关系数据库。
H2是一个开源的嵌入式数据库引擎,采用java语言编写,不受平台的限制,同时H2提供了一个十分方便的web控制台用于 *** 作和管理数据库内容。H2还提供兼容模式,可以兼容一些主流的数据库,因此采用H2作为开发期的数据库非常方便。
H2最大的用途在于可以同应用程序打包在一起发布,这样可以非常方便地存储少量结构化数据。
它的另一个用途是用于单元测试。启动速度快,而且可以关闭持久化功能,每一个用例执行完随即还原到初始状态。
H2的第三个用处是作为缓存,作为NoSQL的一个补充。当某些场景下数据模型必须为关系型,可以拿它当Memcached使,作为后端MySQL/Oracle的一个缓冲层,缓存一些不经常变化但需要频繁访问的数据,比如字典表、权限表。不过这样系统架构就会比较复杂了。
扩展资料:
H2数据库运行方式:
1、内存模式
数据库只在内存中运行,关闭连接后数据库将被清空,适合测试环境,连接字符串:jdbc:h2:mem:DBNameDB_CLOSE_DELAY=-1,如果不指定DBName,则以私有方式启动,只允许一个连接。
2、嵌入式
数据库持久化存储为单个文件。连接字符串:jdbc:h2:file:~/.h2/DBNameAUTO_SERVER=TRUE。~/.h2/DBName表示数据库文件的存储位置,如果第一次连接则会自动创建数据库。
3、服务模式
H2支持三种服务模式:web server:此种运行方式支持使用浏览器访问H2 Console。
CP server:支持客户端/服务器端的连接方式。
PG server:支持PostgreSQL客户端。
参考资料:百度百科-H2
h2数据库递归查不来数据原因如下。1、可能出现类型不匹配的问题:例如数据库中存储的是int类型的值,前端传递过来的是string类型的值,所以查询不到匹配的数据。
2、还有就是可能存在数据库缓存的问题:这里数据库的二级缓存,即是对数据的crud有影响,每次的crud之后,查询的数据都是从数据库的缓存中获取的数据,不是从数据库中获取的最新的数据。
在 H2 数据库中,使用 @sql 语句可以在命令行模式下执行 SQL 脚本。当执行 @sql 语句时,H2 数据库会一次性读取 SQL 脚本文件中的所有 SQL 语句,并逐一执行。因此,执行 @sql 语句就意味着 SQL 脚本中包含的所有 SQL 语句都会被执行一次。如果脚本中包含多条 SQL 语句,则这些 SQL 语句会按照顺序依次执行。
需要注意的是,在执行 @sql 语句时,如果 SQL 脚本中的某条语句出现了错误,则整个执行过程会中断,并显示相应的错误信息。此时,后续的 SQL 语句将不会被执行。
因此,在编写 SQL 脚本时,应注意保证语法正确和逻辑合理,以确保脚本能够顺利执行。同时,也可以在脚本中添加异常处理代码,以便能够捕捉并处理潜在的错误。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)