這篇文章主要講解了“數(shù)據(jù)庫的數(shù)據(jù)模型是什么”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“數(shù)據(jù)庫的數(shù)據(jù)模型是什么”吧!
玉泉街道網(wǎng)站建設公司創(chuàng)新互聯(lián),玉泉街道網(wǎng)站設計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為玉泉街道1000多家提供企業(yè)網(wǎng)站建設服務。企業(yè)網(wǎng)站搭建\外貿(mào)網(wǎng)站制作要多少錢,請找那個售后服務好的玉泉街道做網(wǎng)站的公司定做!
數(shù)據(jù)模型(Data Model)
storm使用tuple來作為它的數(shù)據(jù)模型。每個tuple是一堆值,每個值有一個名字,并且每個值可以是任何類型, 在我的理解里面一個tuple可以看作一個沒有方法的java對象??傮w來看,storm支持所有的基本類型,字符串以及字節(jié)數(shù)組作為tuple的值類 型。你也可以使用你自己定義的類型來作為值類型, 只要你實現(xiàn)對應的序列化器(serializer)。
topology里面的每個節(jié)點必須定義它要發(fā)射的tuple的每個字段。 比如下面這個bolt定義它鎖發(fā)射的tuple包含兩個字段,類型分別是: doble和triple。
publicclass DoubleAndTripleBolt implements IRichBolt { private OutputCollectorBase _collector; @Override
publicvoid prepare(Map conf, TopologyContext context, OutputCollectorBase collector){
_collector = collector; }
@Override
publicvoid execute(Tuple input){ int val = input.getInteger(0);
_collector.emit(input, new Values(val*2, val*3)); _collector.ack(input); }
@Override
publicvoid cleanup(){ }
@Override
publicvoid declareOutputFields(OutputFieldsDeclarer declarer){
declarer.declare(new Fields("double", "triple")); } }
declareOutputFields方法定義要輸出的字段 : ["double", "triple"]。這個bolt的其它部分我們接下來會解釋。
感謝各位的閱讀,以上就是“數(shù)據(jù)庫的數(shù)據(jù)模型是什么”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對數(shù)據(jù)庫的數(shù)據(jù)模型是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!