摘 要:在网上搜索,搜到此文,可解决以下问题:当你想把某数据库的自定义菜单加入到自己开发的数据系统中时,可用此方法,迅速解决。
正 文:
一、自定义菜单的存放位置:
所有自定义菜单都存放在系统表:MsysCmdbars 当中,类型为二进制
如果没有MsysCmdbars或表中没有记录, 说明没有自定义菜单
二、MsysCmdbars的结构
所有自定义菜单的资料都存放在[Grptbcd]二进制字段中,包括名称、图标、引用代码。。。
字段[TBNAME]仅作参考用
三、MsysCmdbars的导入和导出
不可以在打MsysCmdbars表的状态下,对数据进行删除或增加,系统会提示:本表不可删除,
数据为读。
但经本人研究发现通过以下方法可对MsysCmdbars表中的数据进行修改或增加:
Dim obj As ADODB.Stream
导出数据:
Function OutMenu()
Dim rs As Recordset, I As Integer, ret
Set rs = CurrentDb.OpenRecordset("Select * from MsysCmdbars")
rs.MoveFirst
Dim obj As New ADODB.Stream
With obj
.Type = adTypeBinary
.Open
.Write rs.Fields(0)
.SaveToFile "N:\Ben.txt", adSaveCreateOverWrite
End With
Set obj = Nothing
Set rs = Nothing
End Function
导入菜单:
Function InMenu()
Dim rs As Recordset, I As Integer, ret
Set rs = CurrentDb.OpenRecordset("Select * from MsysCmdbars")
Dim obj As New ADODB.Stream
With obj
.Type = adTypeBinary
.Open
.LoadFromFile "N:\Ben.txt"
rs.AddNew
rs.Fields(0) = .Read
rs.Fields(1) = "SHIPMenu"
rs.Update
End With
Set obj = Nothing
Set rs = Nothing
End Function
用以上的方法就可以很容易保存自己精心设计的菜单为TXT 或其他文件, 使用时再导入就可以了
至于二进制数据结构就没进行深入研究,如哪位有更深入的研究心得,希望能给我发个MAIL
Word教程网 | Excel教程网 | Dreamweaver教程网 | Fireworks教程网 | PPT教程网 | FLASH教程网 | PS教程网 |
HTML教程网 | DIV CSS教程网 | FLASH AS教程网 | ACCESS教程网 | SQL SERVER教程网 | C语言教程网 | JAVASCRIPT教程网 |
ASP教程网 | ASP.NET教程网 | CorelDraw教程网 |