前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >java h2 数据库_H2数据库介绍「建议收藏」

java h2 数据库_H2数据库介绍「建议收藏」

作者头像
全栈程序员站长
发布2022-11-04 15:20:16
7500
发布2022-11-04 15:20:16
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

一、H2数据库简介

1、H2数据库是一个开源的关系型数据库。H2是一个嵌入式数据库引擎,采用java语言编写,不受

平台的限制,同时支持网络版和嵌入式版本,有比较好的兼容性,支持相当标准的sql标准,支持集群

2、提供JDBC、ODBC访问接口,提供了非常友好的基于web的数据库管理界面

二、在Java中操作H2数据库

1、以嵌入式(本地)连接方式连接H2数据库

这种连接方式默认情况下只允许有一个客户端连接到H2数据库,有客户端连接到H2数据库之后,

此时数据库文件就会被锁定,那么其他客户端就无法再连接了。

连接语法:jdbc:h2:[file:][]

例如:

jdbc:h2:~/test //连接位于用户目录下的test数据库

jdbc:h2:file:/data/sample

jdbc:h2:file:E:/H2/gacl(Windows only)

2、使用TCP/IP的服务器模式(远程连接)方式连接H2数据库(推荐)

这种连接方式就和其他数据库类似了,是基于Service的形式进行连接的,因此允许多个客户端同

时连接到H2数据库

连接语法:jdbc:h2:tcp://[:]/[]

范例:jdbc:h2:tcp://localhost/~/test

3、H2数据库的内存模式

(1)、H2数据库被称为内存数据库,因为它支持在内存中创建数据库和表

(2)、注意:如果使用H2数据库的内存模式,那么我们创建的数据库和表都只是保存在内存中,

一旦服务器重启,那么内存中的数据库和表就不存在了。

public class H2ConnTest01 {

/**

* 以嵌入式(本地)连接方式连接H2数据库

*/

//private static final String JDBC_URL = “jdbc:h2:C:/H2/abc”;

/**

* 使用TCP/IP的服务器模式(远程连接)方式连接H2数据库(推荐)

*/

private static final String JDBC_URL = “jdbc:h2:tcp://10.35.14.122/C:/H2/user”;

private static final String USER = “user”;

private static final String PASSWORD = “1234”;

private static final String DRIVER_CLASS = “org.h2.Driver”;

public static void main(String[] args) throws Exception {

Class.forName(DRIVER_CLASS);

Connection conn = DriverManager.getConnection(JDBC_URL, USER, PASSWORD);

Statement statement = conn.createStatement();

statement.execute(“DROP TABLE IF EXISTS USER_INF”);

statement.execute(“CREATE TABLE USER_INF(id INTEGER PRIMARY KEY ,name VARCHAR(100), sex VARCHAR(2))”);

statement.executeUpdate(“INSERT INTO USER_INF VALUES(1, ‘tom’, ‘男’) “);

statement.executeUpdate(“INSERT INTO USER_INF VALUES(2, ‘jack’, ‘女’) “);

statement.executeUpdate(“INSERT INTO USER_INF VALUES(3, ‘marry’, ‘男’) “);

statement.executeUpdate(“INSERT INTO USER_INF VALUES(4, ‘lucy’, ‘男’) “);

ResultSet resultSet = statement.executeQuery(“select * from USER_INF”);

while (resultSet.next()) {

System.out.println(resultSet.getInt(“id”) + “, ” + resultSet.getString(“name”) +

“, ” + resultSet.getString(“sex”));

}

statement.close();

conn.close();

}

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/182673.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月12日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档