數(shù)據(jù)庫自動備份的文件怎么比較小 軟件開發(fā)時數(shù)據(jù)在后臺是如何保存的?
軟件開發(fā)時數(shù)據(jù)在后臺是如何保存的?數(shù)據(jù)的存儲有很多種。根據(jù)不同的需求可以不做出差別的選擇。我們以變更土地性質(zhì)一個問答系統(tǒng)為例,來詳細(xì)介紹再看看他們的相同使用場景和方法。關(guān)系型數(shù)據(jù)庫依靠關(guān)系型數(shù)據(jù)庫諸如
軟件開發(fā)時數(shù)據(jù)在后臺是如何保存的?
數(shù)據(jù)的存儲有很多種。根據(jù)不同的需求可以不做出差別的選擇。我們以變更土地性質(zhì)一個問答系統(tǒng)為例,來詳細(xì)介紹再看看他們的相同使用場景和方法。
關(guān)系型數(shù)據(jù)庫依靠關(guān)系型數(shù)據(jù)庫諸如MySQL,是最常用的一種。剛開始開發(fā)個簡單問答系統(tǒng)。你就是可以建幾張表:
上面的實體關(guān)系圖是我剛用PlantUML畫的一個更簡練版,解決理解。源代碼在這里:
@startuml!defineTable(name,desc)classnamethoughdescltlt(T,#FFAAAA)gtgt!defineprimary_key(x)ltbgtxlt/bgt!defineunique(x)ltcolor:greengtxlt/colorgt!definecannot_null(x)ltugtxlt/ugthidemethodshidestereotypesentitiesTable(users,users
(存儲用戶信息)){primary_key(id)INTEGERnot_null(unique(username))VARCHAR[32]actually_null(password)VARCHAR[64]ageSMALLINTgenderSMALLINTbirthdayDATETIME}Table(questions,questions
(存儲問題信息)){primary_key(question_id)INTEGERnot_null(unique(userid))INTEGERtitleVARCHAR[255]contentVARCHAR[2048]creationTimeDATETIMEupdateTimeDATETIME}Table(answers,answers
(存儲問題的答案)){primary_key(answer_id)INTEGERprimary_key(question_id)INTEGERnot_null(unique(userid))INTEGERcontentVARCHAR[2048]creationTimeDATETIMEupdateTimeDATETIME}relationshipsonedidmayrelationship,一對多的關(guān)系users--gtquestions:1個用戶提了多個問題users--dstrokanswers:1個用戶寫了多個問題的答案questions--rlmanswers:1個問題有多個答案@enduml
我是用VSCODE的插件畫的:
設(shè)計好表然后就是可以在MySQL里面建表。
假如你用Java做,這個可以用來JPA框架做數(shù)據(jù)存儲。簡單點可以借用MyBatis。MyBatis是另一個Java不持久化框架,它是從XML描述符或注解把對象與SQL語句關(guān)聯(lián)下來,簡單點、容易上手。建議您剛開始是可以用來這種練練手。
古怪一些的可以利用Hibernate。Hibernate是三個開放源代碼的對象關(guān)系映射框架,要是你喜歡面向?qū)ο蟮木幊蹋蔷褪强梢杂脕鞨ibernate把你設(shè)計什么的對象映射到數(shù)據(jù)庫的單獨的表,比較方便存取。不過這些低些復(fù)雜,學(xué)習(xí)出聲都很花時間。
NoSQL你也這個可以利用NoSQL數(shù)據(jù)庫,也更加很簡單。比如說是一個設(shè)計和實現(xiàn)分布式文件存儲的閉源數(shù)據(jù)庫系統(tǒng)。你可以把上面的表都啊,設(shè)計成JSON文檔,真接讀取在mongodb里面。
全文檢索elasticsearch如果沒有要支持全文檢索,你是需要用Elasticsearch。Elasticsearch是個分布式的全文搜索引擎。
緩存Redis如果你的用戶量大了,要能提高系統(tǒng)的訪問速度。你不需要會用到特殊緩存技術(shù)諸如redis。
消息系統(tǒng)Kafka如果你的系統(tǒng)發(fā)展壯大了,又開發(fā)出很多那些的系統(tǒng)。比如說推薦系統(tǒng),審查系統(tǒng)。你的那里系統(tǒng)與是需要消息通訊。你還是需要用到消息系統(tǒng)Kafka。
我有幾個視頻,利用動畫來演示和解釋Kafka的原理,希望能搜尋和評論。
分布式存儲HadoopHDFS伴隨著你的用戶的增加,內(nèi)容的增加,你的網(wǎng)站每天有一種幾百GB甚至還幾百TB的數(shù)據(jù)。你就必須都用到分布式存儲Hadoop。
我也彼此分享了一些跪求Hadoop的視頻,依靠動畫來演示Hadoop的原理實現(xiàn)程序,歡迎大家關(guān)注。
總結(jié)據(jù)系統(tǒng)的不同需求和不同發(fā)展階段,可以不你選相同的存儲。假如是一就開始目的是驗正自己的產(chǎn)品的想法,也就是做PoC(proveoftheconcept),那你也可以你選簡單易用的,比如MySQL,MongoDB等。等將來系統(tǒng)發(fā)展中了,根據(jù)是需要再怎么升級存儲,諸如ES,redis,kafka也有hadoop。
上面說的各種存儲都意見其它編程語言,Java,Python,Ruby,NodeJS和。簡單易用。
如果沒有是個人學(xué)習(xí)技術(shù),個人建議從最簡單結(jié)束,做一個小的項目,比如說我給的問答的例子。慢慢的體會完全不同的技術(shù)的差別使用方法和應(yīng)用場景。
期望是可以幫到你。有問題可以在評論區(qū)知道回答,我會再次幫忙解決。
本人,@小馬過河Vizit,專注心于分布式系統(tǒng)原理和實踐能分享。如果能依靠動畫生動而又詳細(xì)地做演示抽象的原理。
麻煩問下我的名字。小馬過河Vizit,意為事事像小馬過河一樣的,是需要自己親自嘗試、探索它才能獲得樂趣和新知。Vizit是指Visualizeit的縮寫。一圖勝千言,希望可以利用動畫來可視化抽象的原理。
歡迎大家關(guān)注,你點贊!謝謝了支持。
endnote數(shù)據(jù)庫里的文件保存在哪?
你可以打開word,手動出的窗口是endnote先檢測到word文檔中的參考文獻(xiàn)引入又出現(xiàn)問題,大意是安裝word文檔中參考文獻(xiàn)的引入路徑在endnote數(shù)據(jù)庫中找不到不兼容文獻(xiàn)或是不兼容文獻(xiàn)太多。估計是你的錄入系統(tǒng)參考文獻(xiàn)后,你要改或則刪除掉或是重新修復(fù)了數(shù)據(jù)庫(例如刪除題錄后原先又導(dǎo)入到,那樣的話倒致題錄內(nèi)容一般,可是題錄索引號相同,出現(xiàn)錯誤)。然后打開的窗口是必須你在數(shù)據(jù)庫中不自動確定再次出現(xiàn)問題的文獻(xiàn)是哪篇。況且兩個數(shù)據(jù)庫合二為一,簡單點辦法是將三個數(shù)據(jù)庫中的絕大部分文獻(xiàn)所有的選定,右擊,選擇“剪切粘貼referencewant”拷備到那個數(shù)據(jù)庫中。其實,導(dǎo)入一個數(shù)據(jù)庫為txt文件,再文件導(dǎo)入到另一個數(shù)據(jù)庫也可,但是適用規(guī)定所含的大量文獻(xiàn)數(shù)據(jù)庫的轉(zhuǎn)移。具體操作可以說附件教程。
很抱歉,問者上傳的圖片的附件未完成