持续更新中...
发现h2数据库
说到为什么要用C#来调用Java数据库h2,原因是制作了一个C#的工具,来对网页服务进行部署,主要是进行一些环境的检查,因为对C#比较熟悉,所以就首先选择了C#语言来做winform程序。
但是当这个程序完成以后,发现winform需要和部署的页面中一些显示数据进行交互,这个时候通过页面上的调试分析无法找到这个数据是怎么来的,后来请搞前端的朋友帮忙查看后发现它的数据读写都封装在jar包,使用JD-GUI工具对jar包查看,结果操作数据的类做过混淆没法反编译,不过发现配置文件中暗藏一些内容,既有对应的sql语句,又有数据库连接账号密码,同时注意到了jdbc:h2,百度查一下,原来这是Java中的一种数据库。
因此出来一种思路,找一个办法,直接使用C#来操作这个数据库
验证h2数据库
虽然通过JD-GUI的结果初步判断数据保存在这个h2数据库中,但是对这个新鲜的玩意不太熟悉,所以我先需要验证一下这个东西是哪个文件?它里面保存了我想要的数据吗?
带着问题首先通过上面
spring.datasource.url=jdbc:h2:file:....
通过后面出现的值找到db文件
(其实最开始没搞过Java没看懂这个写法,把h2当成了语法的一种;以为这个是SQLit之类的数据库,就使用Navicat Premium这样的数据库工具尝试了很久,发现都无法打开这个文件)
最后通过DbVisualizer工具打开
不过使用该工具打开的时候需要注意一个问题,也是我在尝试的时候才发现:
①如果使用H2 embedded方式打开文件,即使选择的是正确的.db文件,它仅仅是在同级目录下创建了一个选中文件名+.mv.db的文件,并将新文件打开(选中文件并未被打开),并且新的数据库文件中不存在任何数据,这个开始困扰了我一会儿,让我一时思考是不是找错文件了。
②所以正确的打开方式是使用H2 server方式连接数据库
Setting Format 需要修改为Database URL
至于后面的URL ,我参考jar包中提供的设置
spring.datasource.url=jdbc:h2:file:文件路径
不过此处文件路径每一级目录需要两个\,并且最后的不是文件全名
例如:
输入账号密码连接成功后
这样就可以在查数据了,经过验证,我所需要的数据的确是在某一张表中,验证成功,接下来就是如何在我的C#工程读取数据库了。
.NET是否能连接h2呢?
在网上百度了一圈,通过诸如什么“C#连接h2数据库”“C# h2”“.net h2”…各种条件搜索,结果出来的全是什么“C#连接MySQL”“h2入门”…之类,让我对是否能成功产生了巨大的怀疑
还有孤单的提问者