Java模拟数据库增删改查

7 篇文章 0 订阅

      因为这个课程设计的年代比较久远而且当时个人水平有限,所以只写出部分当时写代码的想法,通过这个课设,有利于理解数据库的基本功能

一下为部分想法:

1.对于数据字典的创建,每次运行程序时,先检测文件是否存在file.exists(),如果存在的话进入下一步,如果不存在则进行创建,数据字典中存储了表名以及字段名

2.对于不同语句的识别,通过正则表达式,但是我只实现了一些基本的语句,不涉及复杂的语法的情况下正则表达式还比较简单

3.接下来的 是我比较特色的一些想法:因为是用文件进行存储,所以需要进行区分

比如对于学生表来说,假设有两个字段 学号和姓名,文件中的形式为

学号  姓名

001  张三

002  李四

需要确定出字段在每一行的位置,比如,查看学生表中的姓名字段的全部信息,需要保证取出来的是第二列而不会取错位置

这里我用了分隔符    ‘---’     每次进行检索字段的时候,先通过分隔符检索出字段前有几个分隔符,然后 在接下来的数据行中,按照相同的分隔符个数进行存取

4.关于表的连接,这里采用了课本上提到的比较直接的方法,用类似笛卡尔积的方法进行等值连接,这时候需要注意的是,当多次比较的时候,如果使用纯IO操作进行对文件的反复读取,需要用到博客中第一篇文章提到的mark()和reset()方法,当然也可以先读到内存中再反复遍历,这样效率高不少

5.上面提到的分隔符是为了能够整齐的存取文件,可以通过Java中的%ms或者%-ms,分别为左补空格和右补空格,可以事先规定一组的长度是10,然后在保证数据长度不超过10的情况下剩余长度进行空格补齐,然后取数据的时候也可以按照相同的长度取可参考 https://wenda.so.com/q/1482091977722144 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

巴塞罗那的风

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

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

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

打赏作者

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

抵扣说明:

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

余额充值