這個(gè)程序會(huì)出現(xiàn)資料庫有的 3 個(gè)朋友,然后加上一個(gè)朋友 Howard,加了之后再將整個(gè)資料庫在控制臺(tái)打印出來,這樣就會(huì)有 4 個(gè)了,多了一個(gè),就是在這里加的。
程序與之前的差異在于加了函數(shù),在這里有 SQL、INSERT、INTO、friends、VALUES,兩個(gè)問號(hào)相對(duì)應(yīng)的是 f_name、f_phone,這是資料庫的名字和電話,這種寫法就可以調(diào)用函數(shù)。
BeaverEE 中文版是一個(gè)數(shù)據(jù)庫連接和操作工具,用于構(gòu)建SQL查詢,編輯和傳輸數(shù)據(jù),查看對(duì)象樹,完成數(shù)據(jù)庫管理任務(wù),監(jiān)視數(shù)據(jù)庫連接會(huì)話等等。本次我們帶來的是最新企業(yè)版,不僅包含了各種基礎(chǔ)功能,還帶來了NoSQL和BigData數(shù)據(jù)庫支持,Visual Query Builder,分析圖表,查詢歷史記錄以及包所有主要驅(qū)動(dòng)程序等,歡迎需要的朋友安裝體驗(yàn)!
DBeaverEE 企業(yè)版軟件介紹
DBeaver 是一個(gè)通用的數(shù)據(jù)庫管理工具,適用于所有需要以專業(yè)方式處理數(shù)據(jù)的人。
使用 DBeaver,您可以像在常規(guī)電子表格中一樣使用數(shù)據(jù)進(jìn)行操作,根據(jù)不同數(shù)據(jù)存儲(chǔ)的記錄創(chuàng)建分析報(bào)告,以適當(dāng)?shù)母袷綄?dǎo)出信息。對(duì)于高級(jí)數(shù)據(jù)庫用戶,DBeaver 建議提供強(qiáng)大的 SQL 編輯器、大量的管理功能、數(shù)據(jù)和模式遷移能力、監(jiān)控?cái)?shù)據(jù)庫連接會(huì)話等等。
DBeaverEE Mac中文版特點(diǎn)介紹
https://mac.orsoon.com/Mac/182312.html?id=MTY4MTYyJl8mMjIwLjE4Ni4zOC4xNTE%3D
連接到各種數(shù)據(jù)源
DBeaver 企業(yè)有針對(duì):
所有這些數(shù)據(jù)庫都有 SQL 接口,您可以與它們一樣與良好的舊關(guān)系數(shù)據(jù)庫合作。
這不是某種JDBC驅(qū)動(dòng)程序抽象-DBeaver EE支持所有這些數(shù)據(jù)庫的所有原生數(shù)據(jù)類型和數(shù)據(jù)庫結(jié)構(gòu)***管理器。
一對(duì)一
高級(jí)安全性
數(shù)據(jù)查看器和編輯器
您可以為表***隨機(jī)數(shù)據(jù)(或"模擬"數(shù)據(jù))。這些數(shù)據(jù)看起來應(yīng)該像***數(shù)據(jù)。
企業(yè)版包括基本和高級(jí)數(shù)據(jù)***器。包括:
SQL 編輯器
視覺查詢***器
https://mac.orsoon.com/Mac/182312.html?id=MTY4MTYyJl8mMjIwLjE4Ni4zOC4xNTE%3D
元數(shù)據(jù)瀏覽器與其元數(shù)據(jù)結(jié)構(gòu)的數(shù)據(jù)庫連接樹下降到最低層:表、視圖、列、索引、程序、觸發(fā)器、存儲(chǔ)實(shí)體(表空間、分區(qū))和安全實(shí)體(用戶、角色)根據(jù)數(shù)據(jù)庫驅(qū)動(dòng)程序功能修改大多數(shù)元數(shù)據(jù)實(shí)體的能力根據(jù)某些數(shù)據(jù)庫的對(duì)象結(jié)構(gòu)顯示數(shù)據(jù)庫對(duì)象的 DDL 和標(biāo)準(zhǔn) SQL92 DDL 的***編輯/重命名/刪除連接和大多數(shù)數(shù)據(jù)庫對(duì)象的能力全球和本地過濾器,按名稱篩選數(shù)據(jù)庫對(duì)象的能力數(shù)據(jù)傳輸將數(shù)據(jù)導(dǎo)出到文件或另一個(gè)數(shù)據(jù)庫表,如果不存在,可以選擇創(chuàng)建目的地表支持的文件格式:CSV、HTML、XML、杰森、XLS、XLSX直接從 CSV 文件導(dǎo)入數(shù)據(jù)到數(shù)據(jù)庫表中。在方便的向?qū)е性O(shè)置列映射和數(shù)據(jù)
類型 將數(shù)據(jù)傳輸配置保存為任務(wù),然后單擊
"計(jì)劃"數(shù)據(jù)傳輸任務(wù)以供日后/經(jīng)常執(zhí)行ER 圖自動(dòng)***數(shù)據(jù)庫/示意圖(包含所有表)或單個(gè)表的 ER 圖(包含所有引用/引用表)列可見性的自定義向格式導(dǎo)出圖表:GIF、PNG、BMP、圖形數(shù)據(jù)和元數(shù)據(jù)搜索針對(duì)所有選定的表/視圖進(jìn)行全文本數(shù)據(jù)搜索,搜索結(jié)果顯示為過濾表/視圖數(shù)據(jù)庫系統(tǒng)表中行之間的元數(shù)據(jù)搜索設(shè)置確切對(duì)象名稱或搜索掩碼的能力數(shù)據(jù)庫結(jié)構(gòu)比較
述 | 楊曉兵
編輯 | 伍杏玲
出品 | CSDN(ID:CSDNnews)
編者前記:
編譯器是連接人類世界與機(jī)器世界之間的一座橋梁,它可將程序員理解的高級(jí)語言,轉(zhuǎn)換成程序高效執(zhí)行的機(jī)器碼。在 C/C++ 編譯器里,有 VC、Borland C++、GCC、Watcom C/C++ 等國外熱門編譯器,但屬于國內(nèi)自主研發(fā)的編譯器較少。
畢竟開發(fā)一款實(shí)用的編譯器不易,涉及前端詞法、語法分析、語意分析、大量的編譯優(yōu)化等工作。而有一支團(tuán)隊(duì),不惜花費(fèi)十余年精力完全自主研發(fā)出一款 YC 編譯器和 YC 瀏覽器內(nèi)核。
為何他們不遺余力地自主研發(fā)編譯器和瀏覽器內(nèi)核?這款編譯器有何優(yōu)點(diǎn)呢?下面由 YC 編譯器的主要作者之一——楊曉兵,來講述這背后十多年來的漫漫研發(fā)路。
以下為楊曉兵自述:
初衷:“做一些對(duì)軟件行業(yè)進(jìn)步有幫助的東西”
十多年前,我在中國科學(xué)院電子學(xué)研究所工作,參與設(shè)計(jì)一些硬件電路。當(dāng)時(shí)我對(duì)硬件的興趣遠(yuǎn)超軟件,后創(chuàng)業(yè)專門從事軟件工作。
我在創(chuàng)業(yè)的過程中發(fā)現(xiàn),做此類軟件雖能賺錢,但無論做得怎樣,對(duì)軟件科學(xué)的進(jìn)步都無絲毫作用。盡管付出很多,卻無成就感。
操作系統(tǒng)、數(shù)據(jù)庫、編譯器以及瀏覽器內(nèi)核是不需要特殊專業(yè)知識(shí)的、開發(fā)難度非常大、最基礎(chǔ)的軟件產(chǎn)品。
我想從這幾種軟件中選擇其中一項(xiàng)來自主研發(fā),雖然不能肯定做出什么成就,但我有希望能做出一些對(duì)軟件行業(yè)進(jìn)步有所幫助的東西,使自己不枉踏入軟件這個(gè)行業(yè)。根據(jù)當(dāng)時(shí)的情況,我發(fā)現(xiàn)可先從瀏覽器內(nèi)核下手,于是我除了維護(hù)原有產(chǎn)品外,把主要精力都投入到瀏覽器的研發(fā)中。
創(chuàng)新將 C 代碼內(nèi)嵌到 HTML
兩年后,我們研發(fā)完成瀏覽器內(nèi)核的基本功能,如 HTML 的解析和顯示、JavaScript 腳本的執(zhí)行等。
此時(shí),我們發(fā)現(xiàn) HTML 的標(biāo)準(zhǔn)越來越復(fù)雜,導(dǎo)致開發(fā)難度越來越大,如果按照這樣的發(fā)展,瀏覽器內(nèi)核將無法走入市場(chǎng)。
于是我重新思考:如果把 C 語言處理成像 JavaScript 腳本嵌入到 HTML 中,用內(nèi)嵌 C 代碼的 HTML 超文本做軟件的人機(jī)交互界面,這款內(nèi)核應(yīng)該會(huì)有點(diǎn)競(jìng)爭(zhēng)優(yōu)勢(shì)。
于是我們花費(fèi)兩年半的時(shí)間將標(biāo)準(zhǔn) C 語言以 JavaScript 相似的方式在 HTML 中執(zhí)行,并擴(kuò)展了一個(gè) HTML 標(biāo)簽:<user>,每個(gè) user 標(biāo)簽都可以用屬性 src 指定一個(gè) C 源碼文件,user標(biāo)簽的顯示界面和所有行為都由它的 C 代碼決定。
同時(shí)將 C 編譯器做成一個(gè)函數(shù),用該函數(shù)編譯生成 C 程序的可執(zhí)行代碼,執(zhí)行代碼可被存入文件或直接執(zhí)行。此時(shí),我們將編譯器取名為 YC 編譯器,瀏覽器內(nèi)核取名為 YC 瀏覽器。
三年又三年,漫漫研發(fā)路
隨后,我們繼續(xù)完善瀏覽器內(nèi)核,將其中的一些內(nèi)核代碼獨(dú)立出來用內(nèi)嵌編譯器動(dòng)態(tài)編譯執(zhí)行,并將大部分內(nèi)核源代碼開源。
與此同時(shí),我們又遇到一個(gè)問題:YC 編譯器雖然編譯速度較快,生成的卻是字節(jié)碼,執(zhí)行速度慢,而且與原生代碼相互調(diào)用(特別是回調(diào)函數(shù))的處理相當(dāng)繁瑣。因此用當(dāng)時(shí)的 YC 編譯器難以勝任開源代碼的編譯工作。
為了解決自編譯瀏覽器內(nèi)核代碼的問題,我們決定修改 YC 編譯器,使它的字節(jié)碼轉(zhuǎn)換為原生的執(zhí)行碼,并擴(kuò)展語法,使之具有少量的 C++ 語法。這個(gè)工作持續(xù)了三年。
三年后,YC 編譯器功能增多,它提供一個(gè)函數(shù)像調(diào)用動(dòng)態(tài)鏈接庫一樣直接調(diào)用 C 源碼中的函數(shù)。此時(shí),瀏覽器內(nèi)核開源部分都可以用 YC 編譯器實(shí)時(shí)編譯執(zhí)行了。
我們繼續(xù)改進(jìn)瀏覽器內(nèi)核,將速度很慢的 JavaScript 字節(jié)碼改為二進(jìn)制原生代碼,使 JavaScript 的執(zhí)行速度約提高約 100 多倍。同時(shí)將瀏覽器內(nèi)核代碼全部模塊化并開源,每個(gè)模塊都用 YC 編譯器動(dòng)態(tài)編譯執(zhí)行,編譯器的部分源碼也開源(如內(nèi)嵌匯編編譯器源碼、反匯編源碼、C/C++ 字節(jié)碼的執(zhí)行源碼等),所有的開源代碼均由內(nèi)嵌的 YC 編譯器自動(dòng)檢測(cè)編譯,動(dòng)態(tài)執(zhí)行。這個(gè)工作大概耗時(shí)四年。
開發(fā)至此,我想起谷歌和火狐瀏覽器都已開源,為什么不去看看它們的源代碼呢?于是找到這兩個(gè)瀏覽器的源碼。
當(dāng)時(shí)由于一些原因,我分析谷歌瀏覽器源碼沒有編譯通過,而火狐的源碼很順利就編譯成功了,于是我就走上了分析火狐源碼之路。
下載的火狐源碼由純 C 代碼和 C++ 代碼兩部分組成,經(jīng) Visual C++ 2013 編譯生成一個(gè) xul.dll 文件和一個(gè) firefox.exe 文件。
我首先分析了它的 C 代碼,將所有的輸出函數(shù)全部改為類接口,并讓 xul.dll 通過 YC 編譯器函數(shù) YC_cppLoad 進(jìn)行實(shí)時(shí)編譯,然后用類接口調(diào)用 C 源碼中的函數(shù)。這一步進(jìn)行得很順利,若修改了火狐的 C 代碼,只要重新運(yùn)行火狐瀏覽器便可生效,無需其它操作。
曾經(jīng)的辦公桌
接下來開始分析火狐 C++ 代碼。YC 編譯器只實(shí)現(xiàn)了少數(shù)幾個(gè) C++ 語法,不能編譯火狐 C++ 代碼,故分析起來非常困難。
為什么火狐 C 代碼容易分析,而它的 C++ 代碼難以分析呢?原來我用 YC 編譯器將它的 C 代碼生成匯編代碼文件、變量結(jié)構(gòu)定義文件、宏定義文件和預(yù)編譯文件,通過這幾個(gè)文件,大大減少了分析難度。
因此我再次決定修改 YC 編譯器,使之完全支持 C++11 標(biāo)準(zhǔn),因?yàn)榛鸷?C++ 代碼幾乎使用了所有的 C++11 語法特性。先使用 STL 標(biāo)準(zhǔn)模板庫代碼進(jìn)行編譯器的修改和調(diào)試,出乎預(yù)料,這個(gè)過程竟用了三年時(shí)間!之后,我用 YC++ 編譯器開始調(diào)試火狐 C++ 代碼。原以為 STL 那么復(fù)雜的代碼都可以編譯通過并正確執(zhí)行,火狐 C++ 代碼應(yīng)該能很快就編譯通過。沒想到,很多語法細(xì)節(jié) STL 沒有用到,而火狐 C++ 源碼用到了。于是又繼續(xù)修改 YC 編譯器,對(duì)火狐 C++ 的各個(gè)模塊進(jìn)行編譯,這個(gè)過程持續(xù)了一年多。
雖然 YC 編譯器可以編譯全部火狐 C++ 代碼,但如何生成執(zhí)行代碼呢?先從主程序 Firefox.cpp 入手,經(jīng)整理,這個(gè)程序可用 YC 編譯器生成執(zhí)行代碼 Firefox.exe,并能順利運(yùn)行。
由于火狐 C++ 各模塊耦合緊密,很難拆分,經(jīng)過一個(gè)多月的工作,仍未能將其拆成多個(gè)獨(dú)立的源碼模塊以便于用 YC 編譯器實(shí)時(shí)編譯,動(dòng)態(tài)執(zhí)行,這也許是我對(duì)火狐 C++ 源碼的整體結(jié)構(gòu)還不甚清楚之故,只見其樹木不見其森林。
楊曉兵
當(dāng)我準(zhǔn)備對(duì)火狐 C++ 代碼進(jìn)行再一次總體分析時(shí),有個(gè)偶然的機(jī)會(huì)參與到一個(gè)學(xué)校管理系統(tǒng)的開發(fā)中,因原有的管理系統(tǒng)經(jīng)常出故障,操作極其不方便。盡管沒有開發(fā) Web 服務(wù)程序的經(jīng)歷,但我做的軟件與 Web 服務(wù)器有極大關(guān)系。
經(jīng)了解,要開發(fā)這種管理系統(tǒng)需要的軟件有:Apache 或 Nginx 服務(wù)器,數(shù)據(jù)庫 MySQL 或其它,編程工具 ASP 或 JSP 或 PHP 等,于是啟發(fā)我們自己研發(fā)這些工具。YC 的 C/C++ 和 JavaScript 編譯器和 HTML 解析器正好派上用場(chǎng)。
經(jīng)過一段時(shí)間,一個(gè)穩(wěn)定的、可任意擴(kuò)展的、多線程高并發(fā)的 HTTP 服務(wù)器就完成了。該服務(wù)器處理 YSP 文件生成網(wǎng)頁傳給瀏覽器。
YSP 是我設(shè)計(jì)的與 ASP、JSP 和 PHP 功能相似的一種網(wǎng)頁編程語言。YC 服務(wù)器執(zhí)行 YSP 文件中的內(nèi)嵌 C/C++ 或 JavaScript 代碼,生成 HTML 超文本傳給終端設(shè)備。工具做好后,不久便做出了管理系統(tǒng)的雛形,這個(gè)雛形在發(fā)布的 YC 編譯器中可見到。
做了上述這些工作后,我想是時(shí)候該寫本書介紹一下 YC 編譯器了,經(jīng)過一段時(shí)間編寫的《YC編譯器—多語言程序設(shè)計(jì)》(暫名)即將出版。
當(dāng)我把書完成后,便立即投入64位的C/C++和JavaScript編譯器的開發(fā),目前開發(fā)進(jìn)展順利,已進(jìn)入測(cè)試階段。
編者后記:
三年時(shí)間,可將一個(gè)呱呱落地的嬰兒變成蹦蹦跳跳的幼兒,可將一名懵懂的職場(chǎng)新人變成沉穩(wěn)的老兵。而楊曉兵團(tuán)隊(duì)沉下心,迎難而上,花費(fèi)三年又三年、再一年、兩年、四年的時(shí)間只為突破一個(gè)個(gè)技術(shù)難點(diǎn),最終自研出 YC 編譯器和 YC 瀏覽器內(nèi)核。
在這過程中,楊曉兵坦言最大的挑戰(zhàn)不僅是技術(shù),還有思維的高度。這期間不僅有大量的研發(fā)工作,還為了優(yōu)化,多次重寫代碼,讓他堅(jiān)持下來的是想為計(jì)算機(jī)軟件科學(xué)的發(fā)展做貢獻(xiàn)的匠心。
目前楊曉兵團(tuán)隊(duì)正在開發(fā) 64 位 C/C++ 編譯器,談及未來,楊曉兵表示先在國內(nèi)推廣,再走向海外。祝福楊曉兵。
YC編譯器傳送門:http://www.ycbro.com
*請(qǐng)認(rèn)真填寫需求信息,我們會(huì)在24小時(shí)內(nèi)與您取得聯(lián)系。