呼唤高手!!!怎么自己开发一个数据库系统

sor 2002-01-29 02:02:40
我要做一个字库软件,客户要求字库保密,否则别人得到了数据库也能够开发一套系统出来,所以不能用通用的数据库
怎么办???
Help!!!
...全文
331 17 打赏 收藏 转发到动态 举报
写回复
用AI写文章
17 条回复
切换为时间正序
请发表友善的回复…
发表回复
sor 2002-01-30
  • 打赏
  • 举报
回复
是啊,对数据加密很慢,而且我的数据库有1.1G,全部是图形字库,放入内存是不可能
to: FrankWu(小精灵) 
能不能说一个内嵌式数据库系统是什么概念,有哪些免费的可用?
FrankWu 2002-01-29
  • 打赏
  • 举报
回复
1、Access2000等通用数据库的密码早已有破解工具;
2、采用楼上的做法不可取:速度太慢!
3、应该采用对数据库文件加密,在打开前进行解密,然后数据操作一如既往,在完成数据操作后又加密;
4、上述方案缺点:如果在数据操作使对方将解密文件得到则可以破解加密!
5、改进:将数据库的文件操作放入内存进行;如果数据文件较大则可以使用一些内嵌式数据库系统:如国产的不常见的一些。。。
JB-Zhang 2002-01-29
  • 打赏
  • 举报
回复
使用任一种数据库,然后对数据进行加密,可达到同样目的!!!!不过速度成问题,自己衡量吧,自己开发?不可能吧?要是可以,你自己可以开一家公司了,别忘了留我一个位子:)
JB-Zhang 2002-01-29
  • 打赏
  • 举报
回复
使用任一种数据库,然后对数据进行加密,可达到同样目的!!!!
luanjiajia 2002-01-29
  • 打赏
  • 举报
回复
你真的想这样做 可以研究mysql
lihonggen0 2002-01-29
  • 打赏
  • 举报
回复
自己开发一个数据库系统,有点难度
不如用二进制文件进行存取
所有的操作变成对文件的操作,
open "xxx" for input
就象用古老的Basic语言一样
fuxc 2002-01-29
  • 打赏
  • 举报
回复
也就是说,按照上面的方法,用Type...End Type定义固定长度的变量,写入文件,这样就可以按照固定长度来区分纪录(记录可以二进制,经过自己加密)
访问文件时,用随机访问方式打开,指定len参数,也就是记录的长度,然后就可以用
seek,eof,loc,get,pot等函数和语句来处理,读出、写入数据。
fuxc 2002-01-29
  • 打赏
  • 举报
回复
使用随机文件访问


File System Object 模式不提供随机文件创建或访问方法。如果需要创建或读取随机文件,此信息将能帮助您。

随机型访问文件中的字节构成相同的一些记录,每个记录包含一个或多个字段。具有一个字段的记录对应于任一标准类型,比如整数或者定长字符串。具有多个字段的记录对应于用户定义类型。例如,下边所定义的 Worker Type 创建由三个字段组成的 19 个字节的记录。

Type Worker
LastNameAs String * 10
TitleAs String * 7
RankAs String * 2
End Type

声明变量
在应用程序打开以随机型访问的文件以前,应先声明所有用来处理该文件数据所需的变量。这包括用户定义类型的变量,它对应该文件中的记录,和标准类型的其它变量,这些变量保存为随机型访问而打开的文件与处理相关的数据

定义记录类型
在打开一个文件进行随机访问之前,应定义一个类型,该类型对应于该文件包含或将包含的记录。例如,一个雇员记录文件可定义一个称为 Person 的用户定义的数据类型,如下所述:

Type Person
ID As Integer
MonthlySalary As Currency
LastReviewDate As Long
FirstName As String * 15
LastName As String * 15
Title As String * 15
ReviewComments As String * 150
End Type

在类型定义中声明字段变量
因为随机访问文件中的所有记录都必须有相同的长度,所以固定的长度对用户定义类型中的各字符串元素通常很有用,就象以上的 Person 类型说明中所示的一样,在此作为例子,FirstName 与 LastName 都具有 15 个字符的固定长度。

如果实际字符串包含的字符数比它写入的字符串元素的固定长度少,则 Visual Basic 会用空白(字符代码 32)来填充记录中后面的空间。还有,如果字符串比字段的尺寸长,则它就会被截断。如果使用 长度可变的字符串,则任何用 Put 存储的或用 Get 检索的记录总长度都不能超过在 Open 语句的 Len 分句中所指定的记录长度。

声明其它变量
在定义与典型记录对应的类型以后,应接着声明程序需要的任何其它变量,用来处理作为随机访问而打开的文件。例如:

'记录变量。
Public Employee As Person
'跟踪当前记录。
Public Position As Long
'文件中最后那条记录的编号。
Public LastRecord As Long

打开随机访问的文件
要打开随机访问的文件,Open 语句使用以下语法:

Open pathname [For Random] As filenumber Len = reclength

因为 Random 是缺省的访问类型,所以 For Random 关键字是可选项。

表达式 Len = reclength 指定了每个记录的尺寸in bytes. Note that every string variable in Visual Basic stores a Unicode string and that you must specify the byte length of that Unicode string。如果 reclength 比写文件记录的实际长度短,则会产生一个错误。如果 reclength 比记录的实际长度长,则记录可写入,只是会浪费些磁盘空间。

可用以下代码打开文件:

Dim FileNum As Integer, RecLength As Long, Employee As Person

'计算每条记录的长度。
RecLength = LenB(Employee)
'取出下一个可用文件编号。
FileNum = FreeFile
'用 Open 语句打开新文件。
Open "MYFILE.FIL" For Random As FileNum Len = RecLength

编辑随机型访问打开的文件
如要编辑随机型访问的文件,请先把记录从文件读到程序变量,然后改变各变量的值,最后,把变量写回该文件。后面各节讨论如何编辑随机型访问打开的文件。

把记录读入变量
使用 Get 语句把记录复制到变量。例如,要把一个记录从雇员记录文件拷贝到 Employee 变量,可使用以下代码:

Get FileNum, Position, Employee

在这行代码中,FileNum 包含用于打开文件的 Open 语句的编号;Position 包含要拷贝的记录数;而 Employee 声明为用户定义类型 Person,它用来接收记录的内容。

把变量写入记录
使用 Put 语句把记录添加或者替换到随机型访问打开的文件。

替换记录
要替换记录,请使用 Put 语句,指定想要替换的记录位置,例如:

Put #FileNum, Position, Employee

这个代码将用 Employee 变量中的数据来替换由 Position 所指定的编号的记录。

添加记录
要向随机访问打开的文件的尾端添加新记录,应使用前述代码段中所示的 Put 语句。把 Position 变量的值设置为比文件中的记录数多 1。例如,要在一个包含五个记录的文件中添加一个记录,把 Position 设置为 6。

下述语句把一个记录添加到文件的末尾:

LastRecord = LastRecord + 1
Put #FileNum, LastRecord, Employee

删除记录
通过清除其字段可以删除一个记录,但是该记录仍在文件中存在。通常文件中不能有空记录,因为它们会浪费空间且会干扰顺序操作。最好把余下的记录拷贝到一个新文件,然后删除老文件。

要清除随机访问文件中删除的记录,请按照以下步骤执行:

创建一个新文件。


把有用的所有记录从原文件复制到新文件。


关闭原文件并用 Kill 语句删除它。


使用 Name 语句把新文件以原文件的名字重新命名。
详细信息 有关随机文件访问的其它信息,请参阅“Open 语句”。
sor 2002-01-29
  • 打赏
  • 举报
回复
2000和xp也都有破解的程序啦
dbcontrols 2002-01-29
  • 打赏
  • 举报
回复
用2000或XP,再说客户能达到你的水平还肯给你银子?
uguess 2002-01-29
  • 打赏
  • 举报
回复
加密的access我自己都有破解密码的源代码

试试2000或XP的吧!应该还没有解密的!
sor 2002-01-29
  • 打赏
  • 举报
回复
加密的access我自己都有破解密码的源代码
CALM 2002-01-29
  • 打赏
  • 举报
回复
自己开发太夸张了吧?
想别的方法吧,去试试其他的文件存贮技术吧
dbcontrols 2002-01-29
  • 打赏
  • 举报
回复
使用加密码的ACCESS吧.如果别人的水平比你高,不会看上你的软件,否则解秘不了.
sam_fs80 2002-01-29
  • 打赏
  • 举报
回复
加密分为软件加密和硬件加密,前一种就是在在软件上加上密匙,后一种是在硬件上将放数据库的硬件锁好。

如你所说,你的字库若泄漏的话,就证明你的保密做得不好,这样的话不论用什么方法也不能保证你的软件的保密性。

要知道,没有什么加密是永远的. 远程的密码破解都搞到专家们头疼了,何况是别人拿了你的文件用本地方式去破解呢 ??
sha_boy 2002-01-29
  • 打赏
  • 举报
回复
也不一定非得编译数据库系统,
你可以编一个将现有的数据库进行加密的软件.
40Star 2002-01-29
  • 打赏
  • 举报
回复
自己开发?!
为什么不去Sybase或者Oracle工作!?

742

社区成员

发帖
与我相关
我的任务
社区描述
VB 版八卦、闲侃,联络感情地盘,禁广告帖、作业帖
社区管理员
  • 非技术类社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧