版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 附錄</b></p><p> 附錄A:外文資料翻譯—原文部分</p><p> Distinctive Features of SQLite</p><p> (From SQLite.Org (http://www.sqlite.org/different.html))</p><p&
2、gt; This passage highlights some of the characteristics of SQLite that are unusual and which make SQLite different from many other SQL database engines. </p><p> Zero-Configuration</p><p> SQ
3、Lite does not need to be "installed" before it is used. There is no "setup" procedure. There is no server process that needs to be started, stopped, or configured. There is no need for an administrato
4、r to create a new database instance or assign access permissions to users. SQLite uses no configuration files. Nothing needs to be done to tell the system that SQLite is running. No actions are required to recover after
5、a system crash or power failure. There is nothing to troubleshoot. </p><p> SQLite just works. </p><p> Other more familiar database engines run great once you get them going. But doing the in
6、itial installation and configuration can be intimidatingly complex. </p><p> Serverless</p><p> Most SQL database engines are implemented as a separate server process. Programs that want to ac
7、cess the database communicate with the server using some kind of interprocess communication (typically TCP/IP) to send requests to the server and to receive back results. SQLite does not work this way. With SQLite, the p
8、rocess that wants to access the database reads and writes directly from the database files on disk. There is no intermediary server process. </p><p> There are advantages and disadvantages to being serverle
9、ss. The main advantage is that there is no separate server process to install, setup, configure, initialize, manage, and troubleshoot. This is one reason why SQLite is a "zero-configuration" database engine. Pr
10、ograms that use SQLite require no administrative support for setting up the database engine before they are run. Any program that is able to access the disk is able to use an SQLite database. </p><p> On th
11、e other hand, a database engine that uses a server can provide better protection from bugs in the client application - stray pointers in a client cannot corrupt memory on the server. And because a server is a single pers
12、istent process, it is able control database access with more precision, allowing for finer grain locking and better concurrency. </p><p> Most SQL database engines are client/server based. Of those that are
13、 serverless, SQLite is the only one that this author knows of that allows multiple applications to access the same database at the same time. </p><p> Single Database File</p><p> An SQLite da
14、tabase is a single ordinary disk file that can be located anywhere in the directory hierarchy. If SQLite can read the disk file then it can read anything in the database. If the disk file and its directory are writable,
15、then SQLite can change anything in the database. Database files can easily be copied onto a USB memory stick or emailed for sharing. </p><p> Other SQL database engines tend to store data as a large collect
16、ion of files. Often these files are in a standard location that only the database engine itself can access. This makes the data more secure, but also makes it harder to access. Some SQL database engines provide the optio
17、n of writing directly to disk and bypassing the filesystem all together. This provides added performance, but at the cost of considerable setup and maintenance complexity. </p><p> Stable Cross-Platform Dat
18、abase File</p><p> The SQLite file format is cross-platform. A database file written on one machine can be copied to and used on a different machine with a different architecture. Big-endian or little-endia
19、n, 32-bit or 64-bit does not matter. All machines use the same file format. Furthermore, the developers have pledged to keep the file format stable and backwards compatible, so newer versions of SQLite can read and write
20、 older database files. </p><p> Most other SQL database engines require you to dump and restore the database when moving from one platform to another and often when upgrading to a newer version of the softw
21、are. </p><p><b> Compact</b></p><p> When optimized for size, the whole SQLite library with everything enabled is less than 225KiB in size (as measured on an ix86 using the "s
22、ize" utility from the GNU compiler suite.) Unneeded features can be disabled at compile-time to further reduce the size of the library to under 170KiB if desired. </p><p> Most other SQL database engin
23、es are much larger than this. IBM boasts that its recently released CloudScape database engine is "only" a 2MiB jar file - 10 times larger than SQLite even after it is compressed! Firebird boasts that its clien
24、t-side library is only 350KiB. That's 50% larger than SQLite and does not even contain the database engine. The Berkeley DB library from Sleepycat is 450KiB and it omits SQL support, providing the programmer with onl
25、y simple key/value pairs. </p><p> Manifest typing</p><p> Most SQL database engines use static typing. A datatype is associated with each column in a table and only values of that particular
26、datatype are allowed to be stored in that column. SQLite relaxes this restriction by using manifest typing. In manifest typing, the datatype is a property of the value itself, not of the column in which the value is stor
27、ed. SQLite thus allows the user to store any value of any datatype into any column regardless of the declared type of that column. (There are some </p><p> As far as we can tell, the SQL language specificat
28、ion allows the use of manifest typing. Nevertheless, most other SQL database engines are statically typed and so some people feel that the use of manifest typing is a bug in SQLite. But the authors of SQLite feel very st
29、rongly that this is a feature. The use of manifest typing in SQLite is a deliberate design decision which has proven in practice to make SQLite more reliable and easier to use, especially when used in combination with dy
30、namically </p><p> Variable-length records</p><p> Most other SQL database engines allocated a fixed amount of disk space for each row in most tables. They play special tricks for handling BLO
31、Bs and CLOBs which can be of wildly varying length. But for most tables, if you declare a column to be a VARCHAR(100) then the database engine will allocate 100 bytes of disk space regardless of how much information you
32、actually store in that column. </p><p> SQLite, in contrast, use only the amount of disk space actually needed to store the information in a row. If you store a single character in a VARCHAR(100) column, th
33、en only a single byte of disk space is consumed. (Actually two bytes - there is some overhead at the beginning of each column to record its datatype and length.) </p><p> The use of variable-length records
34、by SQLite has a number of advantages. It results in smaller database files, obviously. It also makes the database run faster, since there is less information to move to and from disk. And, the use of variable-length reco
35、rds makes it possible for SQLite to employ manifest typing instead of static typing. </p><p> Readable source code</p><p> The source code to SQLite is designed to be readable and accessible t
36、o the average programmer. All procedures and data structures and many automatic variables are carefully commented with useful information about what they do. Boilerplate commenting is omitted. </p><p> SQL
37、statements compile into virtual machine code</p><p> Every SQL database engine compiles each SQL statement into some kind of internal data structure which is then used to carry out the work of the statement
38、. But in most SQL engines that internal data structure is a complex web of interlinked structures and objects. In SQLite, the compiled form of statements is a short program in a machine-language like representation. User
39、s of the database can view this virtual machine language by prepending the EXPLAIN keyword to a query. </p><p> The use of a virtual machine in SQLite has been a great benefit to the library's developme
40、nt. The virtual machine provides a crisp, well-defined junction between the front-end of SQLite (the part that parses SQL statements and generates virtual machine code) and the back-end (the part that executes the virtua
41、l machine code and computes a result.) The virtual machine allows the developers to see clearly and in an easily readable form what SQLite is trying to do with each statement it compiles, wh</p><p> Public
42、domain</p><p> The source code for SQLite is in the public domain. No claim of copyright is made on any part of the core source code. (The documentation and test code is a different matter - some sections o
43、f documentation and test logic are governed by open-source licenses.) All contributors to the SQLite core software have signed affidavits specifically disavowing any copyright interest in the code. This means that anybod
44、y is able to legally do anything they want with the SQLite source code. </p><p> There are other SQL database engines with liberal licenses that allow the code to be broadly and freely used. But those other
45、 engines are still governed by copyright law. SQLite is different in that copyright law simply does not apply. </p><p> The source code files for other SQL database engines typically begin with a comment de
46、scribing your license rights to view and copy that file. The SQLite source code contains no license since it is not governed by copyright. Instead of a license, the SQLite source code offers a blessing: </p><p
47、> May you do good and not evil</p><p> May you find forgiveness for yourself and forgive others</p><p> May you share freely, never taking more than you give. </p><p> SQL la
48、nguage extensions</p><p> SQLite provides a number of enhancements to the SQL language not normally found in other database engines. The EXPLAIN keyword and manifest typing have already been mentioned above
49、. SQLite also provides statements such as REPLACE and the ON CONFLICT clause that allow for added control over the resolution of constraint conflicts. SQLite supports ATTACH and DETACH commands that allow multiple indepe
50、ndent databases to be used together in the same query. And SQLite defines APIs that allows the user </p><p> 附錄B:外文資料翻譯—譯文部分</p><p> SQLite與眾不同的特性</p><p> ?。ㄒ?SQLite官方網(wǎng)站(http://w
51、ww.sqlite.org/different.html))</p><p> 這篇文章介紹了SQLite一些不尋常的特性,這些特性使SQLite與其它許多SQL數(shù)據(jù)庫引擎不同。</p><p><b> 無需配置</b></p><p> SQLite在使用前不需要“安裝”。沒有“設(shè)置”的程序。沒有需要啟動(dòng)、停止或者配置的服務(wù)器進(jìn)程。沒
52、有必要讓一名管理員去創(chuàng)建一個(gè)新的數(shù)據(jù)庫實(shí)例或者給用戶分配使用權(quán)限。SQLite使用無配置的文件。無需做任何事情來告知系統(tǒng)SQLite正在運(yùn)行。在系統(tǒng)或者電源故障后不需任何操作來恢復(fù)。沒有任何問題需要解決。</p><p> SQLite就能夠這么運(yùn)行著。</p><p> 其它許多我們熟悉的數(shù)據(jù)庫引擎一旦你讓它們運(yùn)行起來,它們將運(yùn)行得非常好。但是前期的安裝和配置可能是相當(dāng)復(fù)雜的。<
53、;/p><p><b> 無服務(wù)器</b></p><p> 大多數(shù)SQL數(shù)據(jù)庫引擎被應(yīng)用為一個(gè)分離的服務(wù)器處理進(jìn)程。需要訪問數(shù)據(jù)庫的程序必須與服務(wù)器進(jìn)行通訊,它們使用一些進(jìn)程間通訊的方法(典型的如TCP/IP)將請求發(fā)送給服務(wù)器并接收發(fā)送回的結(jié)果。SQLite不采用這種方法工作。對(duì)于SQLite而言,需要訪問數(shù)據(jù)庫的進(jìn)程直接讀寫保存在磁盤上的數(shù)據(jù)庫文件。不存在中間的
54、服務(wù)器進(jìn)程。</p><p> 無服務(wù)器有其優(yōu)點(diǎn)和缺點(diǎn)。主要優(yōu)點(diǎn)是它沒有分開的服務(wù)器進(jìn)程需要去安裝、設(shè)置、配置、初始化、管理和排錯(cuò)。這正是SQLite被稱為“零配置”數(shù)據(jù)庫引擎的原因之一。使用SQLite的程序,在啟動(dòng)之前,不需要管理員去配置數(shù)據(jù)庫引擎。任何能夠讀取磁盤的程序都能使用SQLite數(shù)據(jù)庫。</p><p> 另外一方面,一個(gè)使用服務(wù)器的數(shù)據(jù)庫引擎在遇到客戶端應(yīng)用程序的Bu
55、g時(shí),可以提供更好的保護(hù)——如客戶端遺失的指針無法釋放服務(wù)器上的內(nèi)存。并且因?yàn)橐粋€(gè)服務(wù)器是一個(gè)單獨(dú)的持續(xù)運(yùn)行的進(jìn)程,它能夠控制數(shù)據(jù)庫進(jìn)行高精度的讀寫,允許完善的原子鎖和更好的并發(fā)控制。</p><p> 大多數(shù)SQL數(shù)據(jù)庫引擎是基于客戶端/服務(wù)器模式的。對(duì)于那些無服務(wù)器的數(shù)據(jù)庫引擎而言,據(jù)筆者所知,SQLite是唯一一個(gè)允許多個(gè)應(yīng)用程序在同一時(shí)間訪問同一個(gè)數(shù)據(jù)庫的數(shù)據(jù)庫引擎。</p><p&
56、gt;<b> 單一數(shù)據(jù)庫文件</b></p><p> 一個(gè)SQLite數(shù)據(jù)庫是一個(gè)單獨(dú)的普通磁盤文件,它可以被放置在目錄結(jié)構(gòu)中的任何位置。如果SQLite能夠讀取該磁盤文件,那么它就可以讀取數(shù)據(jù)庫中的任何內(nèi)容。如果該磁盤文件和它所處的文件夾是可寫入的,那么SQLite能夠更改數(shù)據(jù)庫中的任何內(nèi)容。數(shù)據(jù)庫文件能夠被非常簡單地拷貝到一個(gè)USB記憶棒中或者通過電子郵件進(jìn)行共享。</p&
57、gt;<p> 其它SQL數(shù)據(jù)庫引擎傾向于將數(shù)據(jù)保存到一個(gè)大規(guī)模的文件集合中。通常這些文件位于一個(gè)標(biāo)準(zhǔn)的地方,只有數(shù)據(jù)庫引擎自己才可以訪問。這使得數(shù)據(jù)更加安全,不過也讓它更難訪問。一些SQL數(shù)據(jù)庫引擎提供了直接寫入磁盤同時(shí)繞過文件系統(tǒng)的選項(xiàng)。這提供了附加的性能,不過是以相當(dāng)大的設(shè)置和維護(hù)復(fù)雜度作為代價(jià)的。</p><p> 穩(wěn)定的跨平臺(tái)數(shù)據(jù)庫文件</p><p> SQ
58、Lite文件格式是跨平臺(tái)的。在一臺(tái)機(jī)器上寫的一個(gè)數(shù)據(jù)庫文件可以被拷貝到一臺(tái)不同架構(gòu)的機(jī)器上并使用。大端或小端存儲(chǔ)、32位或64位不是問題。所有的機(jī)器使用相同的文件格式。此外,開發(fā)者保證文件格式的平穩(wěn)和向下兼容,所以SQLite更新的版本能夠讀寫老版本的數(shù)據(jù)庫文件。</p><p> 大多數(shù)其它的SQL數(shù)據(jù)庫引擎要求你切斷并且恢復(fù)數(shù)據(jù)庫,當(dāng)你要將數(shù)據(jù)庫從一個(gè)平臺(tái)轉(zhuǎn)移到另一個(gè)平臺(tái)時(shí),或者當(dāng)你升級(jí)到一個(gè)更新版本的軟件
59、時(shí)。</p><p><b> 簡潔</b></p><p> 當(dāng)優(yōu)化文件大小時(shí),一個(gè)開啟所有功能的完整的SQLite庫小于225KB(使用ix86中GNU編譯套件的“size”工具測量)。如果需要的話,不必要的特性可以在編譯時(shí)禁用,以便于進(jìn)一步減少庫文件的大小使其低于170KB。</p><p> 大多數(shù)其他的SQL數(shù)據(jù)庫引擎比這個(gè)大得
60、多。IBM聲稱,它近期發(fā)布的CloudScape數(shù)據(jù)庫引擎“僅僅”為一個(gè)2MB的jar文件(譯者注:一種JAVA的軟件壓縮包格式)——即使它處于壓縮狀態(tài),其大小依舊是SQLite的10倍!Firebird聲稱它的客戶端庫文件只有350KB大小。那還是比SQLite大了50%,并且還不包括數(shù)據(jù)庫引擎。來自Sleepycat的Berkeley DB庫文件是450KB,并且它省略了對(duì)SQL的支持,為程序員提供的僅僅是簡單的鍵/值對(duì)。</
61、p><p><b> 弱類型</b></p><p> 大多數(shù)SQL數(shù)據(jù)庫引擎使用靜態(tài)類型。一種數(shù)據(jù)類型與一張表中的每一列相關(guān)聯(lián),并且只有屬于該特定數(shù)據(jù)類型的數(shù)據(jù)被允許存放在該列中。SQLite通過使用弱類型(manifest typing)來減少這種限制。在弱類型中,數(shù)據(jù)類型是數(shù)據(jù)自己的一個(gè)屬性,而不是數(shù)據(jù)所在列的屬性。因此SQLite允許用戶存儲(chǔ)任何數(shù)據(jù)類型的值到
62、任何列中,而不必考慮該列聲明的數(shù)據(jù)類型。(這一規(guī)則有一些例外:一個(gè)INTEGER PRIMARY KEY類型的列只能存儲(chǔ)整數(shù)。并且在可能的情況下,SQLite會(huì)試圖將值強(qiáng)行轉(zhuǎn)換為該列聲明的數(shù)據(jù)類型。)</p><p> 至于我們可以告訴你的是,SQL語言規(guī)范允許使用弱類型。不過,大多數(shù)其它的SQL數(shù)據(jù)庫引擎都使用靜態(tài)類型,所以因此一些人認(rèn)為SQLite使用弱類型是一個(gè)Bug。不過SQLite的作者非常堅(jiān)持地認(rèn)為
63、這是一個(gè)特性。在SQLite中使用弱類型是一個(gè)經(jīng)過深思熟慮的設(shè)計(jì)方案,它在實(shí)踐中已被證實(shí)使SQLite更可靠并易于使用,尤其在與使用動(dòng)態(tài)類型的編程語言,如Tcl和Python,結(jié)合使用時(shí)。</p><p><b> 可變長度記錄</b></p><p> 大多數(shù)其它的SQL數(shù)據(jù)庫引擎被分配一個(gè)固定數(shù)量的磁盤空間來存儲(chǔ)大多數(shù)表的每一行。它們使用特定的技巧來處理可能無
64、限大的BLOB和CLOB類型數(shù)據(jù)。不過對(duì)于大多數(shù)的表,如果你聲明一個(gè)類型為VARCHAR(100)的列,然后數(shù)據(jù)庫引擎將分配100個(gè)字節(jié)的磁盤空間,而不考慮你將在該列中實(shí)際存儲(chǔ)多少信息。</p><p> 相比之下,SQLite只使用存儲(chǔ)一行數(shù)據(jù)信息所需的實(shí)際磁盤空間。如果你在一個(gè)VARCHAR(100)類型的列中存儲(chǔ)一個(gè)單字符,那么它僅消耗一個(gè)字節(jié)的磁盤空間。(實(shí)際上是兩個(gè)字節(jié)——在每一列的開頭有一些額外的空
65、間用來存儲(chǔ)它的數(shù)據(jù)類型和長度。)</p><p> SQLite通過使用可變長度記錄有很多優(yōu)勢。很顯然,它使數(shù)據(jù)庫文件更小。它也讓數(shù)據(jù)庫運(yùn)行更快,因?yàn)樗枰獜拇疟P上讀寫的數(shù)據(jù)也更少。并且,對(duì)可變長度記錄的使用使SQLite用弱類型替換靜態(tài)類型成為可能。</p><p><b> 易讀的源代碼</b></p><p> SQLite的源代碼
66、被設(shè)計(jì)為易于閱讀的,并且一般的程序員也可以理解。所有的程序、數(shù)據(jù)結(jié)構(gòu)和自動(dòng)化變量都有詳盡的注釋,包含有用的信息和開發(fā)者做了些什么。引用注釋被省略了。</p><p> SQL語句編譯為虛擬機(jī)器碼</p><p> 每個(gè)SQL數(shù)據(jù)庫引擎都會(huì)將每條SQL語句編譯為一些內(nèi)部的數(shù)據(jù)結(jié)構(gòu),然后被用來執(zhí)行語句所指定的工作。不過在大多數(shù)的SQL引擎中,內(nèi)部數(shù)據(jù)結(jié)構(gòu)是一張由互聯(lián)的結(jié)構(gòu)和對(duì)象組成的復(fù)雜網(wǎng)
67、絡(luò)。在SQLite中,語句編譯的形式為一段短小的類似描述的機(jī)器語言程序。數(shù)據(jù)庫的用戶可以通過在一個(gè)查詢前追加EXPLAIN關(guān)鍵字的方式來查看這種虛擬機(jī)器語言。</p><p> SQLite對(duì)虛擬機(jī)的使用為程序庫的開發(fā)帶來了極大的便利。虛擬機(jī)在SQLite的前臺(tái)(從語法上分析SQL語句并生成虛擬機(jī)器碼的部分)和后臺(tái)(運(yùn)行虛擬機(jī)器碼并且計(jì)算結(jié)果的部分)之間提供了一個(gè)簡單的、定義明確的結(jié)合點(diǎn)。虛擬機(jī)用易于閱讀的形式
68、讓開發(fā)者看清SQLite對(duì)每句編譯好的語句嘗試做什么,這對(duì)調(diào)試有極大的幫助。根據(jù)它是如何編譯的,SQLite同樣有能力追蹤虛擬機(jī)的指令——打印每個(gè)虛擬機(jī)的指令和它運(yùn)行的結(jié)果。</p><p><b> 公共領(lǐng)域</b></p><p> SQLite的源代碼位于公共領(lǐng)域。任何核心部分的源代碼都沒有聲明版權(quán)。(文檔和測試代碼是另一回事——一部分的文檔和測試邏輯是由開
69、源許可管理的。)所有對(duì)于SQLite核心軟件的貢獻(xiàn)者都已簽署宣誓書否定任何代碼的版權(quán)利益。這意味著任何人用SQLite的源代碼能夠合法地做他們想做的任何事情。</p><p> 還有一些簽署了自由協(xié)議的SQL數(shù)據(jù)庫引擎的源代碼允許被自由地傳播和使用。不過其它的引擎依舊被著作權(quán)法保護(hù)。SQLite的不同點(diǎn)在于著作權(quán)法根本不適用。</p><p> 其它SQL數(shù)據(jù)庫引擎的源代碼文件典型的一
70、般以一段描述你許可查看和拷貝文件權(quán)利的注釋開始。SQLite的源代碼不包含許可,因?yàn)樗槐话鏅?quán)管理。取代許可的是,SQLite的源代碼提供一個(gè)信念:</p><p> 愿你多做好事少做壞事</p><p> 愿你自我寬恕也寬恕他人</p><p> 愿你無私分享,不要獲取的比你付出的更多</p><p><b> SQL語言
71、擴(kuò)展</b></p><p> SQLite提供了一些增強(qiáng)的SQL語言通常不會(huì)在其它數(shù)據(jù)庫引擎中出現(xiàn)。EXPLAIN關(guān)鍵字和弱類型上面已經(jīng)提過了。SQLite還提供了諸如REPLACE和ON CONFICT子句,允許用戶控制約束沖突的情況。SQLite支持ATTACH和DETACH命令,它們允許用戶將多個(gè)相互獨(dú)立的數(shù)據(jù)庫聯(lián)合起來完成同一個(gè)查詢。并且SQLite定義了允許用戶添加新SQL功能和排序序列
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 與眾不同作文
- yahoo!—與眾不同的酷!
- 與眾不同的魅力牛仔
- 只求一份與眾不同
- 每個(gè)郵輪,都與眾不同
- 勵(lì)志演講稿你與眾不同
- 成功人士與眾不同的九種做法
- 產(chǎn)科出血和輸血與眾不同
- 與眾不同升學(xué)宴致辭5篇
- 托福高分范文:從眾還是與眾不同?
- 勁霸男裝與眾不同的五年上海之舞
- 聚焦“社會(huì)熱點(diǎn)”給學(xué)生與眾不同的地理課堂
- 燃油特性外文翻譯
- 外文翻譯---多孔磨耗層在不同的馬歇爾壓實(shí)作用下的特性
- 外文翻譯---多孔磨耗層在不同的馬歇爾壓實(shí)作用下的特性
- 外文翻譯--電梯的負(fù)載特性
- 外文翻譯---多孔磨耗層在不同的馬歇爾壓實(shí)作用下的特性
- 外文翻譯--減振器的特性仿真
- 外文翻譯--竹子的機(jī)械特性
- 與眾不同的匹薩店,四年開店十多家
評(píng)論
0/150
提交評(píng)論