一、建立一個(gè)數(shù)據(jù)庫(kù)利用C語(yǔ)言調(diào)用數(shù)據(jù)庫(kù)的數(shù)據(jù)來(lái)進(jìn)行運(yùn)算得到運(yùn)算結(jié)果
你直接使用創(chuàng)建命令(CREATE DATABASE ..)即可,然后利用提供的C語(yǔ)言的API函數(shù)訪問(wèn)數(shù)據(jù)庫(kù)即可,你預(yù)算可以借助SELECT在數(shù)據(jù)庫(kù)中完成,也可以選擇SELECT讀出數(shù)據(jù)到內(nèi)存中,借助C語(yǔ)言預(yù)算完成,沒(méi)啥技術(shù)難度而言
數(shù)據(jù)庫(kù)簡(jiǎn)單實(shí)現(xiàn):
該程序在windows環(huán)境,dev c++編譯器下正常編譯運(yùn)行,linux下需要自行編寫strnicmp()與itoa()。
由于時(shí)間的限制,在塊存儲(chǔ)結(jié)構(gòu)以及數(shù)據(jù)字典表的存儲(chǔ)上進(jìn)行了簡(jiǎn)化,若之后要實(shí)現(xiàn)同步等操作的實(shí)現(xiàn)將會(huì)出現(xiàn)錯(cuò)誤,還有較多的冗余代碼,沒(méi)有抽取封裝成單獨(dú)的函數(shù)。SELECT的實(shí)現(xiàn)只支持單表查詢,WHERE語(yǔ)句只支持一個(gè)過(guò)濾表達(dá)式。其中有部分歸并排序和外排序的代碼沒(méi)有完成,但是SELECT中有塊內(nèi)排序的函數(shù)。
該程序是數(shù)據(jù)庫(kù)的簡(jiǎn)單實(shí)現(xiàn),包含INSERT插入操作,CREATE建表操作,SELECT查詢操作,在數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)時(shí)考慮了DELETE刪除操作,所以在Item結(jié)構(gòu)中增加了bool型變量IsDelete標(biāo)記是否已經(jīng)刪除,因?yàn)樵趐ostgresql中的DELETE是假刪除,所以DELETE操作很容易實(shí)現(xiàn),我也在顯示的函數(shù)里加入了IsDeleted的判斷,有需要自行獨(dú)立添加相關(guān)函數(shù)即可。自定義表(ID為10000以上,文件名即為ID)在文件存儲(chǔ)中是以塊(頁(yè))形式存儲(chǔ)的,大小為8K,元組的長(zhǎng)度是變長(zhǎng)的,字符串也是變長(zhǎng)存儲(chǔ)。
該程序?qū)崿F(xiàn)的主要難度在于數(shù)據(jù)結(jié)構(gòu)的設(shè)計(jì),指針操作,內(nèi)存中數(shù)據(jù)存儲(chǔ)理解以及文件操作。
涉及的核心函數(shù)主要有:
內(nèi)存操作 malloc()、free()、memcpy()
文件操作 fopen()、fclose()、fread()、fseek()、fwrite()
總體難度不大。
延伸閱讀:
二、Django 是什么
Django 是一個(gè)高級(jí)的 Python 網(wǎng)絡(luò)框架,可以快速開發(fā)安全和可維護(hù)的網(wǎng)站。由經(jīng)驗(yàn)豐富的開發(fā)者構(gòu)建,Django 負(fù)責(zé)處理網(wǎng)站開發(fā)中麻煩的部分,因此你可以專注于編寫應(yīng)用程序,而無(wú)需重新開發(fā)。 它是免費(fèi)和開源的,有活躍繁榮的社區(qū),豐富的文檔,以及很多免費(fèi)和付費(fèi)的解決方案。
Django 可以使你的應(yīng)用具有以下優(yōu)點(diǎn):
完備性
Django 遵循“功能完備”的理念,提供開發(fā)人員可能想要“開箱即用”的幾乎所有功能。因?yàn)槟阈枰囊磺卸际且粋€(gè)”產(chǎn)品“的一部分,它們都可以無(wú)縫結(jié)合在一起,遵循一致性設(shè)計(jì)原則,并且具有廣泛和最新的文檔。
通用性
Django 可以(并已經(jīng))用于構(gòu)建幾乎任何類型的網(wǎng)站—從內(nèi)容管理系統(tǒng)和維基,到社交網(wǎng)絡(luò)和新聞網(wǎng)站。它可以與任何客戶端框架一起工作,并且可以提供幾乎任何格式(包括 HTML,Rss 源,JSON,XML 等)的內(nèi)容。你正在閱讀的網(wǎng)站就是基于 Django。
在內(nèi)部,盡管它為幾乎所有可能需要的功能(例如幾個(gè)流行的數(shù)據(jù)庫(kù),模版引擎等)提供了選擇,但是如果需要,它也可以擴(kuò)展到使用其他組件。
安全性
Django 幫助開發(fā)人員通過(guò)提供一個(gè)被設(shè)計(jì)為“做正確的事情”來(lái)自動(dòng)保護(hù)網(wǎng)站的框架來(lái)避免許多常見的安全錯(cuò)誤。例如,Django 提供了一種安全的方式來(lái)管理用戶賬戶和密碼,避免了常見的錯(cuò)誤,比如將 session 放在 cookie 中這種易受攻擊的做法(取而代之的是 cookies 只包含一個(gè)密鑰,實(shí)際數(shù)據(jù)存儲(chǔ)在數(shù)據(jù)庫(kù)中)或直接存儲(chǔ)密碼而不是密碼哈希。
密碼哈希是通過(guò)密碼散列函數(shù)發(fā)送密碼而創(chuàng)建的固定長(zhǎng)度值。Django 能通過(guò)運(yùn)行哈希函數(shù)來(lái)檢查輸入的密碼 – 就是 – 將輸出的哈希值與存儲(chǔ)的哈希值進(jìn)行比較是否正確。然而由于功能的“單向”性質(zhì),即時(shí)存儲(chǔ)的哈希值受到威脅,攻擊者也難以解決原始密碼。(但其實(shí)有彩虹表 – 譯者觀點(diǎn))
默認(rèn)情況下,Django 可以防范許多漏洞,包括 SQL 注入,跨站點(diǎn)腳本,跨站點(diǎn)請(qǐng)求偽造和點(diǎn)擊劫持。