Access數(shù)據(jù)庫(kù)對(duì)于文本和備注類型的數(shù)據(jù)類型定義(DATA_TYPE)都是為130,無(wú)法直接區(qū)分,找了N多網(wǎng)頁(yè),包括MSDN都沒(méi)有描述有關(guān)COLUMN_FLAGS的說(shuō)明,還是自己分析一下:
COLUMN_FLAGS為64位(8字節(jié))的十六進(jìn)制的值,組合了數(shù)據(jù)類型和必填字段等信息
其中最后2個(gè)字節(jié)有效,最后一個(gè)字節(jié)一直為0x0A,有變化的是最后第二個(gè)字節(jié),即:
對(duì)于文本類型的為0x00;備注類型為0x80;
對(duì)于非必填字段為0x40;必填字段為0x60
組合后:
文本必填: 0x6A
文本非必填:0x4A
備注必填: 0xEA
備注非必填:0xCA
最后可以得到COLUMN_FLAGS右移7位后可以區(qū)分文本類型和備注類型
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為文本字段
}
}
COLUMN_FLAGS為64位(8字節(jié))的十六進(jìn)制的值,組合了數(shù)據(jù)類型和必填字段等信息
其中最后2個(gè)字節(jié)有效,最后一個(gè)字節(jié)一直為0x0A,有變化的是最后第二個(gè)字節(jié),即:
對(duì)于文本類型的為0x00;備注類型為0x80;
對(duì)于非必填字段為0x40;必填字段為0x60
組合后:
文本必填: 0x6A
文本非必填:0x4A
備注必填: 0xEA
備注非必填:0xCA
最后可以得到COLUMN_FLAGS右移7位后可以區(qū)分文本類型和備注類型
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為文本字段
}
}