No SQL for Fun and Profit: Brief Introduction

56 252 0
No SQL for Fun and Profit: Brief Introduction

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

Thông tin tài liệu

A NoSQL or Not Only SQL database provides a mechanism for storage and retrieval of data that is modeled in means other than the tabular relations used in relational databases. Motivations for this approach include simplicity of design, horizontal scaling and finer control over availability. The data structure (e.g. keyvalue, graph, or document) differs from the RDBMS, and therefore some operations are faster in NoSQL and some in RDBMS. There are differences though, and the particular suitability of a given NoSQL DB depends on the problem it must solve (e.g., does the solution use graph algorithms?). The appearance of mature NoSQL databases has reduced the rationale for Java content repository (JCR) implementations. NoSQL databases are increasingly used in big data and realtime web applications. NoSQL systems are also called Not only SQL to emphasize that they may also support SQLlike query languages. Many NoSQL stores compromise consistency (in the sense of the CAP theorem) in favor of availability and partition tolerance. Barriers to the greater adoption of NoSQL stores include the use of lowlevel query languages, the lack of standardized interfaces, and huge investments in existing SQL. Most NoSQL stores lack true ACID transactions, although a few recent systems, such as FairCom ctreeACE, Google Spanner and FoundationDB, have made them central to their designs.

NOSQL Profit! & for Fun TIM ANGLADE PROUDLY PRESENTS PART TWO OF THE TOTALLY UNKOWN “FUN & PROFIT” SERIES. A TALE OF TECH, INTRIGUE & FORBIDDEN LOVE. A WHIRLWIND OF ADVENTURERS, PRODUCTION SYSTEMS &TROLLS. A STORY SO BIG, ITS TITLE HAD TO HAVE ITS OWN INTRODUCTION TEXT. HERE IS… @TIMANGLADE Hit me up. I don’t bite… too hard. AN ANNOUNCEMENT NØSQL rope! Eu LONDON, APRIL 20 TH & 21 ST WORKSHOPS AND TRAINING ON THE 22 ND FOLLOW @NOSQLEU FOR DETAILS A WARNING This is Tech for Managers. Don’t Blame Me. 40 YEARS IN THE DESERT Information Retrieval P. BAXENDALE, Editor A Relational Model of Data for Large Shared Data Banks E. F. CODD IBM Research Laboratory, San Jose, California Future users of large data banks must be protected from having to know how the data is organized in the machine (the internal representation). A prompting service which supplies such information is not a satisfactory solution. Activities of users at terminals and most application programs should remain unaffected when the internal representation of data is changed and even when some aspects of the external representation are changed. Changes in data representation will often be needed as a result of changes in query, update, and report traffic and natural growth in the types of stored information. Existing noninferential, formatted data systems provide users with tree-structured files or slightly more general network models of the data. In Section 1, inadequacies of these models are discussed. A model based on n-ary relations, a normal form for data base relations, and the concept of a universal data sublanguage are introduced. In Section 2, certain opera- tions on relations (other than logical inference) are discussed and applied to the problems of redundancy and consistency in the user’s model. KEY WORDS AND PHRASES: data bank, data base, data structure, data organization, hierarchies of data, networks of data, relations, derivability, redundancy, consistency, composition, join, retrieval language, predicate calculus, security, data integrity CR CATEGORIES: 3.70, 3.73, 3.75, 4.20, 4.22, 4.29 1. Relational Model and Normal Form 1 .I. INTR~xJ~TI~N This paper is concerned with the application of ele- mentary relation theory to systems which provide shared access to large banks of formatted data. Except for a paper by Childs [l], the principal application of relations to data systems has been to deductive question-answering systems. Levein and Maron [2] provide numerous references to work in this area. In contrast, the problems treated here are those of data independence-the independence of application programs and terminal activities from growth in data types and changes in data representation-and certain kinds of data inconsistency which are expected to become troublesome even in nondeductive systems. Volume 13 / Number 6 / June, 1970 The relational view (or model) of data described in Section 1 appears to be superior in several respects to the graph or network model [3,4] presently in vogue for non- inferential systems. It provides a means of describing data with its natural structure only-that is, without superim- posing any additional structure for machine representation purposes. Accordingly, it provides a basis for a high level data language which will yield maximal independence be- tween programs on the one hand and machine representa- tion and organization of data on the other. A further advantage of the relational view is that it forms a sound basis for treating derivability, redundancy, and consistency of relations-these are discussed in Section 2. The network model, on the other hand, has spawned a number of confusions, not the least of which is mistaking the derivation of connections for the derivation of rela- tions (see remarks in Section 2 on the “connection trap”). Finally, the relational view permits a clearer evaluation of the scope and logical limitations of present formatted data systems, and also the relative merits (from a logical standpoint) of competing representations of data within a single system. Examples of this clearer perspective are cited in various parts of this paper. Implementations of systems to support the relational model are not discussed. 1.2. DATA DEPENDENCIES IN PRESENT SYSTEMS The provision of data description tables in recently de- veloped information systems represents a major advance toward the goal of data independence [5,6,7]. Such tables facilitate changing certain characteristics of the data repre- sentation stored in a data bank. However, the variety of data representation characteristics which can be changed without logically impairing some application programs is still quite limited. Further, the model of data with which users interact is still cluttered with representational prop- erties, particularly in regard to the representation of col- lections of data (as opposed to individual items). Three of the principal kinds of data dependencies which still need to be removed are: ordering dependence, indexing depend- ence, and access path dependence. In some systems these dependencies are not clearly separable from one another. 1.2.1. Ordering Dependence. Elements of data in a data bank may be stored in a variety of ways, some involv- ing no concern for ordering, some permitting each element to participate in one ordering only, others permitting each element to participate in several orderings. Let us consider those existing systems which either require or permit data elements to be stored in at least one total ordering which is closely associated with the hardware-determined ordering of addresses. For example, the records of a file concerning parts might be stored in ascending order by part serial number. Such systems normally permit application pro- grams to assume that the order of presentation of records from such a file is identical to (or is a subordering of) the Communications of the ACM 377 Information Retrieval P. BAXENDALE, Editor A Relational Model of Data for Large Shared Data Banks E. F. CODD IBM Research Laboratory, San Jose, California Future users of large data banks must be protected from having to know how the data is organized in the machine (the internal representation). A prompting service which supplies such information is not a satisfactory solution. Activities of users at terminals and most application programs should remain unaffected when the internal representation of data is changed and even when some aspects of the external representation are changed. Changes in data representation will often be needed as a result of changes in query, update, and report traffic and natural growth in the types of stored information. Existing noninferential, formatted data systems provide users with tree-structured files or slightly more general network models of the data. In Section 1, inadequacies of these models are discussed. A model based on n-ary relations, a normal form for data base relations, and the concept of a universal data sublanguage are introduced. In Section 2, certain opera- tions on relations (other than logical inference) are discussed and applied to the problems of redundancy and consistency in the user’s model. KEY WORDS AND PHRASES: data bank, data base, data structure, data organization, hierarchies of data, networks of data, relations, derivability, redundancy, consistency, composition, join, retrieval language, predicate calculus, security, data integrity CR CATEGORIES: 3.70, 3.73, 3.75, 4.20, 4.22, 4.29 1. Relational Model and Normal Form 1 .I. INTR~xJ~TI~N This paper is concerned with the application of ele- mentary relation theory to systems which provide shared access to large banks of formatted data. Except for a paper by Childs [l], the principal application of relations to data systems has been to deductive question-answering systems. Levein and Maron [2] provide numerous references to work in this area. In contrast, the problems treated here are those of data independence-the independence of application programs and terminal activities from growth in data types and changes in data representation-and certain kinds of data inconsistency which are expected to become troublesome even in nondeductive systems. Volume 13 / Number 6 / June, 1970 The relational view (or model) of data described in Section 1 appears to be superior in several respects to the graph or network model [3,4] presently in vogue for non- inferential systems. It provides a means of describing data with its natural structure only-that is, without superim- posing any additional structure for machine representation purposes. Accordingly, it provides a basis for a high level data language which will yield maximal independence be- tween programs on the one hand and machine representa- tion and organization of data on the other. A further advantage of the relational view is that it forms a sound basis for treating derivability, redundancy, and consistency of relations-these are discussed in Section 2. The network model, on the other hand, has spawned a number of confusions, not the least of which is mistaking the derivation of connections for the derivation of rela- tions (see remarks in Section 2 on the “connection trap”). Finally, the relational view permits a clearer evaluation of the scope and logical limitations of present formatted data systems, and also the relative merits (from a logical standpoint) of competing representations of data within a single system. Examples of this clearer perspective are cited in various parts of this paper. Implementations of systems to support the relational model are not discussed. 1.2. DATA DEPENDENCIES IN PRESENT SYSTEMS The provision of data description tables in recently de- veloped information systems represents a major advance toward the goal of data independence [5,6,7]. Such tables facilitate changing certain characteristics of the data repre- sentation stored in a data bank. However, the variety of data representation characteristics which can be changed without logically impairing some application programs is still quite limited. Further, the model of data with which users interact is still cluttered with representational prop- erties, particularly in regard to the representation of col- lections of data (as opposed to individual items). Three of the principal kinds of data dependencies which still need to be removed are: ordering dependence, indexing depend- ence, and access path dependence. In some systems these dependencies are not clearly separable from one another. 1.2.1. Ordering Dependence. Elements of data in a data bank may be stored in a variety of ways, some involv- ing no concern for ordering, some permitting each element to participate in one ordering only, others permitting each element to participate in several orderings. Let us consider those existing systems which either require or permit data elements to be stored in at least one total ordering which is closely associated with the hardware-determined ordering of addresses. For example, the records of a file concerning parts might be stored in ascending order by part serial number. Such systems normally permit application pro- grams to assume that the order of presentation of records from such a file is identical to (or is a subordering of) the Communications of the ACM 377 WHAT DO YOU MEAN BY “THE DESERT”? THE GOOD A strong ecosystem. [...]... Puzzlement Noun paradigm (plural paradigms) 1 An example serving as a model or pattern 2 A system of assumptions, concepts, values, and practices that constitutes a way of viewing reality SQL Just say no A NOT-SO-NOVEL IDEA Information Retrieval P BAXENDALE, A Relational Model of Data for Large Shared Data Banks E F CODD IBM Research Laboratory, Future users having to know internal large information and. .. needed and Existing with internal some a result in models of the form for data sublanguage tions on and data model WORDS calculus, and (other stored than the logical problems of provide general users network of these relations, concept In Section models a normal of a universal 2, certain inference) are redundancy be report information systems more often and and operadiscussed consistency model AND PHRASES:... provides a basis for a high level data language which will yield maximal independence between programs on the one hand and machine representation and organization of data on the other A further advantage of the relational view is that it forms a sound basis for treating derivability, redundancy, and consistency of relations-these are discussedin Section 2 The network model, on the other hand, has spawned... [3,4] presently in vogue for noninferential systems It provides a means of describing data with its natural structure only-that is, without superimposing any additional structure for machine representation purposes Accordingly, it provides a basis for a high level data language which will yield maximal independence between programs on the one hand and machine representation and organization of data... data on the other A further advantage of the relational view is that it forms a sound basis for treating derivability, redundancy, and consistency of relations-these are discussedin Section 2 The network model, on the other hand, has spawned a number of confusions, not the least of which is mistaking the derivation of connections for the derivation of relations (seeremarks in Section 2 on the “connection... Jose, California data, bank, data networks of composition, data join, data base, data, retrieval relations, language, structure, data derivability, predicate integrity 3.70, 3.73, Model 3.75, and 4.20, 4.22, Normal 4.29 Form 1.I INTR~xJ~TI~N This paper is concerned with the application of elementary relation theory to systems which provide shared access large banks of formatted data Except for a paper... HADOOP MNESIA CASSANDRA CASSANDRA HBASE JACKRABBIT VOLDEMORT GT.M DYNOMITE MEMCACHEDB BIGTABLE DYNAMO SHERPA ORACLE SPATIAL ORACLE SPATIAL ESRI ARCGIS SAND CITRUSLEAF NEPTUNE 1 2 3 4 5 6 7 DOCUMENT KEY–VALUE GRAPH COLUMN/BIGTABLE GEO OBJECT FILESYSTEM 1 2 3 4 5 6 FLAT!DOCUMENT, FILESYSTEM ASSOCIATIVE!KEY-VALUE HIERARCHICAL!GEO NETWORK!GRAPH DIMENSIONAL!COLUMN OBJECTIONAL!OBJECT FOR THE SQL- ERS I made... dependencies which still need to be removed are: ordering dependence, indexing dependence, and accesspath dependence In some systems these dependencies are not clearly separable from one another 1.2.1 Ordering Dependence Elements of data in a data bank may be stored in a variety of ways, someinvolving no concern for ordering, some permitting each element to participate in one ordering only, others permitting... question-answering systems Levein and Maron [2] provide numerous referencesto work in this area In contrast, the problems treated here are those of data independence-the independence of application programs and terminal activities from growth in data types and changesin data representation -and certain kinds of data inconsistency which are expected to become troublesome even in nondeductive systems Volume... permits a clearer evaluation of the scope and logical limitations of present formatted data systems, and also the relative merits (from a logical standpoint) of competing representations of data within a single system Examples of this clearer perspective are cited in various parts of this paper Implementations of systems to support the relational model are not discussed IN 1.2 DATA DEPENDENCIES PRESENTSYSTEMS . NOSQL Profit! & for Fun TIM ANGLADE PROUDLY PRESENTS PART TWO OF THE TOTALLY UNKOWN “FUN &. ANNOUNCEMENT NØSQL rope! Eu LONDON, APRIL 20 TH & 21 ST WORKSHOPS AND TRAINING ON THE 22 ND FOLLOW @NOSQLEU FOR DETAILS A WARNING This is Tech for Managers. Don’t Blame Me. 40 YEARS IN THE DESERT Information

Ngày đăng: 21/07/2014, 11:53

Từ khóa liên quan

Tài liệu cùng người dùng

Tài liệu liên quan