Access数据库的文本、备注数据类型的COLUMN_FLAGS说明

Access数据库对于文本和备注类型的数据类型定义(DATA_TYPE)都是为130,无法直接区分,找了N多网页,包括MSDN都没有描述有关COLUMN_FLAGS的说明,还是自己分析一下:

    COLUMN_FLAGS为64位(8字节)的十六进制的值,组合了数据类型和必填字段等信息

其中最后2个字节有效,最后一个字节一直为0x0A,有变化的是最后第二个字节,即:
    对于文本类型的为0x00;备注类型为0x80;
    对于非必填字段为0x40;必填字段为0x60

组合后:
   文本必填:  0x6A
   文本非必填:0x4A
   备注必填:  0xEA
   备注非必填:0xCA
   
最后可以得到COLUMN_FLAGS右移7位后可以区分文本类型和备注类型


DataTable dt = m_OLEDBCon.GetOleDbSchemaTable(
    OleDbSchemaGuid.Columns,
    new object[] {null, null, "表名称", null});

DataRow[] drs = dt.Select("COLUMN_NAME='字段名称'");
if(drs.Length > 0 && Convert.ToInt32(drs[0]["DATA_TYPE"]) == 130) {
    //文本类型
    if ( (Convert.ToInt64(drs[0]["COLUMN_FLAGS"]) >> 7) == 1){
        //=1为备注字段       
    }else{
        //=0为文本字段
    }
}
posted @ 2008-05-22 10:10 dannyr|一个都不能少! 阅读(1755) 评论(4)  编辑 收藏 所属分类: .Net技术

  回复  引用    
#1楼 2008-05-22 11:10 | 城里人 [未注册用户]
深入研究呀
  回复  引用  查看    
#2楼 2008-05-22 15:51 | margiex      
odbc取了schema之后有个type_name可以得到,不过memo类型为longchar
  回复  引用  查看    
#3楼 2008-05-22 19:28 | 李涛      
这个问题,平时用access做后台数据库开发中基本没关注过。楼主很有钻研之心啊,赞一个!

标题  
姓名  
主页
Email (只有博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2008-05-22 10:12 编辑过


相关链接: