• AE中读写Blob字段


    在之前,我都尽量避免读写blob字段,原因如下
    第一:不方便手工维护。
    第二:不方便做数据转换。
    第三:其他人不知道里面放了什么,对于交流上有障碍。
    最近,由于项目的需要,不得不去实现blob字段的读写。
    AE的对象都是存在数据库中里的blob字段的,他自己实现了对象的流化(序列化),那么他一定也提供了接口出来。大不了,用API去读写。这是我最初的想法。
    这其中探索的过程就不多说了,下面用代码来说明
            void SaveHistoryToFld(IFeature pFea, THistorys pHistorys)
            {
                IFormatter formatter = new BinaryFormatter();
                Stream Ms = new MemoryStream();
                formatter.Serialize(Ms, pHistorys);//对象序列化
                int n = (int)Ms.Length;
                Ms.Position = 0;
                byte[] pReadByte = new Byte[n];
                Ms.Read(pReadByte, 0, n);//读取到内存中
                IMemoryBlobStream2 pBlob = new MemoryBlobStreamClass();
                pBlob.ImportFromMemory(ref pReadByte[0], (uint)n);//转到AE认可的接口中
                SetFldValue(pFea, CC_History, pBlob);//保存
            }
            bool LoadHistoryFromFld(IFeature pFea, out THistorys pHistorys)
            {
                pHistorys = null;
                object pObj = GetFldValue(pFea, CC_History);//读取blob字段
                if (pObj == null || pObj == DBNull.Value) return false;
                IMemoryBlobStream2 pBlob = new MemoryBlobStreamClass();
                pBlob = (IMemoryBlobStream2)pObj;//转换到AE认可的内存流中
                int n = (int)pBlob.Size;
                byte[] pReadByte = new Byte[n];
                object pObj2 = null;
                (pBlob as IMemoryBlobStreamVariant).ExportToVariant(out pObj2);//输出到变量
                pReadByte = (byte[])pObj2;//强制转换为字节数组
                Stream Ms = new MemoryStream();
                Ms.Write(pReadByte, 0, n);//强制转换为内存流
                Ms.Position = 0;
                IFormatter formatter = new BinaryFormatter();
                pHistorys = (THistorys)formatter.Deserialize(Ms);//反序列化
                return true;
            }
    代码如此清楚,我就不多说了。^_^
  • 相关阅读:
    Java程序开发必备的6种知识
    Java技术在多数据库系统中的应用研究
    解决J2EE系统应用性能问题常用方法
    在Java中如何跳出当前的多重嵌套循环?
    Java学习是由简入难的学习过程
    浅谈Java SE、Java EE、Java ME三者的区别
    J2ee的学习方法及步骤摘要
    IOS 使用GCD改善性能
    IOS Cell重用机制
    BUG--tomcat更改目录失败
  • 原文地址:https://www.cnblogs.com/feedback/p/1208275.html
Copyright © 2020-2023  润新知