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