文件存儲表的欄位設計
㈠ 資料庫文件的表結構由欄位組成,欄位包括哪四部分
應該是「記錄的集合構成表內容,欄位的集合構成表結構」吧
㈡ 資料庫欄位設計的問題
1、在資料庫設計時 不需要每個欄位 都加新欄位的
2、其實qq這個很容易實現的,就是許可權的問題
3、用角色判斷許可權 就可以了
4、或者在列表中 使用div 動態生成 也可以,這樣還簡單些
㈢ 怎樣創建Access中存儲OLE對象欄位
Access中的「OLE對象」欄位可以用來存儲文檔、圖片、聲音的數據以及在別的程序中創建的其他類型的二進制數據,並且可以鏈接或嵌入到Microsoft Access表的欄位中。那麼,如何創建一個OLE對象的欄位呢,下面以建一個存儲聲音的欄位為例。在」設計視圖」中打開表,選中需要輸入的行,在「欄位名稱」列中鍵入欄位名稱「聲音」,在「數據類型」列中,單擊箭頭並選擇「OLE對象」即可。
㈣ 在資料庫存儲結構設計時要考慮哪些因素
第一:各個參數是否對應的一個對象(面向對象編程思想);
第二:各個參數可能類型和出現的最大長度,之後合理的設計各個欄位的最大長度和相應類型;
第三:各個參數中哪些欄位具有唯一性,考慮作為主鍵或者是外鍵來進行表關聯;
第四:根據數據量的大小來考慮是否需要進行分區處理;
第五:哪些欄位是不經常便跟欄位,可以考慮進行多張表的存儲來節省存儲空間(可能影響查詢修改效率)
㈤ 數據表文件中的欄位是什麼
數據表中的欄位:
欄位是資料庫中的數據表中的一列,數據表是由幾個或幾十個欄位組成,是在記錄中放置數據的,一個記錄就可以放置不同的數據在不同的欄位中,一個數據表就是由這樣的記錄組成的。
㈥ word文檔存入資料庫,資料庫表裡的欄位類型應該設置成什麼
在sql server中將要存儲word文檔的表的欄位的datatype設為image.(image類型並不一定要存圖象,它是二進制格式存儲,任何數據均可,如果存多種類型, 可利用另一欄位存文件類型,並不需要知道文件格式)
數據存取方法用ADO時可利用AppendChunk 和GetChunk來存取image欄位,在delphi中根據你採用的數據存取方法,可利用類似函數.
㈦ 存儲文件的資料庫是怎麼設計的
不知道你要存什麼,大概就是樹型的目錄吧,4個欄位:
文件名file_name,文件路徑file_url,父路徑parent_url,值value
㈧ 如何設計動態欄位的產品資料庫表
可以採用四種技術:
動態增加資料庫表欄位
預留足夠的空白欄位,運行時作動態影射
用xml格式保存在單欄位里
改列為行,用另外一個表存放定製欄位
【一】
現在我們來分析一下四種技術的優劣,不過首先可以排除的是第一點動態增加欄位的方法,因為在實際操作時候幾乎是不可能的(sqlserver太慢,oracle索性不支持),基本可以不討論就排除。剩下後三點。
【二】
先來討論預留空白欄位的方法,基本原理就是在資料庫表設計的時候加入一些多餘的欄位,看下面的代碼:
CREATE TABLE Sample(
name varchar(12),
field0 varchar(1),
field1 varchar(1),
fieldN varchar(1)
}
然後看實際運行時候的需要,動態分配欄位給系統使用,也許需要一個這樣的結構來描述分配情況:
public class Available
{
public int CurrentUnusedFieldNumber;
public Hashtable FieldToRealName;
}
也許某一時刻的數據狀況是這樣的: CurrentUnusedFieldNumber=3,
哈西表FieldToRealName包含內容是("field0"="SomeId", "field1"="AnyName",
"field2=IsOk")
現在的問題是如果要配合Hibernate,如何來處理?以上段的數據使用狀況為例子,如果我們的類定義是這樣:
public class Entity01
{
public string Name;
public string SomeId;
public string AnyName;
public bool IsOk;
}
也許只需要修改一下xxx.hbm.xml,把 SomeId 和 field0
做成對應就ok了。但是在運行時我們怎麼知道會有這樣的類定義?除非我們做動態代碼生成,自動編譯也許可以,但是問題也許就到其他方面去了;如果我們不用動態定義,那麼類就只能是這樣:
public class Entity01
{
public string Name;
public Hashtable ExtraFieldAndValues;
}
使用的時候,用 entity01.ExtraFieldAndValues.setValue("AnyName", "boss")
的方式來引用,也許這樣是修改最少的了,但是問題是Hibernate不支持這樣的方法。
【三】
再來討論單欄位存儲的方法,我們使用這樣的資料庫表定義
CREATE TABLE Sample
(
Name varchar(12),
Xml CLOB(102400) // 僅作說明而已
)
然後對應這樣的類定義
public class Entity01
{
public string Name;
public string Xml;
public Hashtable ExtraNameAndValueFromXml;
}
我們的代碼就可以這樣使用:string id =
entity01.ExtraNameAndValueFromXml.getValue("SomeId")
了。這樣解決看起來很不錯,不僅不需要Available表,而且看起來Hibernate對它的支持也很完美,但是致命的問題在於:如果保持高效的查詢?除非資料庫系統本身對此有支持,否則就只能用低效的substring或者like做查詢,這在大批量數據中根本就不可行。
是不是折衷一下,把兩種方法的優點和起來?問題有來了:怎麼保持兩者之間數據的同步?難道要我們用存儲過程去解析xml內容?
所以,一個兩難的問題,需要我們認真去解決。我們通過認真的需求分析,也許可以減少可變欄位的數量,但是只要有一個可變欄位或者可變的可能性存在,我們始終要去解決這個兩難的問題。
期待繼續討論。
【四】
還有一種方法就是改列為行,用另外一個表存放擴展欄位,定義可以如下:
CREATE
TABLE SampleFields
(
idSample Integer,
fieldName varchar(30),
fieldValue varchar(100)
)
其中idSample關聯到Sample表的id欄位(我沒有寫出來)。這樣的話,Hibernate很容易支持,也可以支持Sql的查詢,而且可以支持把內容放到Hashtable中去,看起來是目前最好的方式了。但是在大容量數據的時候,SampleFields表的數據會是主表數據量的N倍(看定製的欄位數目多少而定),同樣存在有很嚴重的性能問題。
㈨ 資料庫表中欄位類型有哪些
資料庫表中欄位類型有二進制數據類型、字元數據類型、數字數據類型 等其中類型。具體類型如下所示:
1、二進制數據類型
Binary、Varbinary、Image
2、字元數據類型
Char,Varchar和 Text
3、Unicode數據類型
包括Nchar,Nvarchar和Ntext
4、日期和時間數據類型
包括Datetime, Smalldatetime, Date, TimeStamp
5、數字數據類型
數字數據類型包括正數和負數、小數和整數
6、貨幣數據類型
表示正的或者負的貨幣數量。
7、特殊數據類型
特殊的數據類型有3種,即Timestamp、Bit 和 Uniqueidentifier。