H2 数据库 备份/恢复 测试 Linux

实操:

1. 创建表,添加数据

1.1 登录 H2 

(h2 目录在 /home/h2/h2中)

java -cp /home/h2/h2/bin/h2*.jar org.h2.tools.Shell

 

1.2 创建3个表,添加1000条数据

1.2.1 创建表

create table t_car1 (id int , car_id text);

create table t_car2 (id int , car_id text);

create table t_car3 (id int , car_id text);

 

 

1.2.2 插入1000 车牌数据

insert into t_car1 select x, '粤' || char( 65 + floor(RANDOM()*25)) || upper(left(RANDOM_UUID(),6)) from SYSTEM_RANGE(1, 1000);

insert into t_car2 select x, '桂' || char( 65 + floor(RANDOM()*25)) || upper(left(RANDOM_UUID(),6)) from SYSTEM_RANGE(1, 1000);

insert into t_car3 select x, '湘' || char( 65 + floor(RANDOM()*25)) || upper(left(RANDOM_UUID(),6)) from SYSTEM_RANGE(1, 1000);

 

1.2.3 查看数据

with a as (select * from t_car1 limit 5),b as (select * from t_car2 limit 5),c as (select * from t_car3 limit 5)

select * from a union all

select * from b union all

select * from c;

 

2. 备份数据库

2.1 脚本备份

java -cp /home/h2/h2/bin/h2*.jar org.h2.tools.Script -url jdbc:h2:~/test_bak_res -user sa -script test_bak_res.zip -options compression zip

zip 里面的文件

 

2.2 在线备份

BACKUP TO 'test_bak_res_backup.zip'

 

 zip 里面文件:

 

2.3 命令行备份

java -cp /home/h2/h2/bin/h2*.jar org.h2.tools.Backup -?

java -cp  /home/h2/h2/bin/h2*.jar org.h2.tools.Backup -file test_bak_res_bb.zip -dir ~ -db test_bak_res

 

Zip 里面文件:

 

3. 恢复

3.1 脚本恢复

java -cp /home/h2/h2/bin/h2*.jar org.h2.tools.RunScript -url jdbc:h2:~/test_res -user sa -script test_bak_res.zip -options compression zip

成功恢复!!

3.2 命令行恢复

java -cp /home/h2/h2/bin/h2*.jar org.h2.tools.Restore -?

java -cp /home/h2/h2/bin/h2*.jar org.h2.tools.Restore -file test_bak_res_bb.zip -dir ~ -db test_res3

ll test_res*

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bigshark_software

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值