CIP Multiple Graphs. Presentation at ocig 8 on April 11, Stefan Plantikow, Andrés Taylor, Petra Selmer (Neo4j)
|
|
- Alison Meryl Page
- 5 years ago
- Views:
Transcription
1 CIP Multiple Graphs Presentation at ocig 8 on April 11, 2018 Stefan Plantikow, Andrés Taylor, Petra Selmer (Neo4j)
2 History Started working on multiple graphs early 2017 Parallel work in LDBC query language task force Built first non-prototype proposal for ocim 3 in Nancy (Nov 2017) Lots of great feedback but outcome incomplete Inspired by Nancy we started to reconstruct the MG proposal Starting from first principles (data model, execution model, language semantics) Incrementally add orthogonal concern Aim for simple, minimal design Reduce scope of work Today: Primer for core of new proposal draft
3 Outline Multiple property graphs model Query processing model (Catalog and working graph) Working with multiple graphs (Matching, updating, returning graphs) Graph operations (Graph projection and graph union) Updating the catalog Examples Discussion (Status, timeline, next steps)
4 Why multiple graphs? - Combining and transforming graphs from multiple sources Graph Management - Versioning, snapshotting, computing difference graphs - Graph views for access control - Provisioning applications with tailored graph views - Shaping and integrating heterogeneous graph data Graph Modeling - Roll-up and drill-down at different levels of detail 4
5 Multiple Property Graph Model
6 Cypher today: (Single) property graph model Graph Database System (e.g. a cluster) Application Server Client 1 Client 2 Client 3 The (single) Graph 6
7 Cypher 10: Multiple property graphs model Graph Database System (e.g. a cluster) Application Server Client 1 Client 2 Client 3 Multiple Graphs 7
8 Classic Property Graph Model A single graph Labeled nodes with properties Typed, directed relationships with properties Multiple Property Graphs Model Multiple graphs Labeled nodes with properties and typed, directed relationships with properties existing in a single graph The nodes of a relationship R must be part of the same graph as R; i.e. each graph is independent 8
9 Graph and entity ids The graph(entity) function returns the graph id of the entity An entity (a node or a relationship) in Cypher 10 needs to track its graph (to differentiate whether or not two entities are from the same graph) graph(entity) is a value that uniquely identifies a graph within the implementation This is a two-way process: a graph will also be aware of the entities it contains The id(entity) function returns the (entity) id of entity in graph(entity) id(entity) is a value that uniquely identifies an entity within its graph and types (i.e. nodes and relationships do not share the id space) The format of ids is implementation specific This does not change between Cypher 9 and Cypher 10 9
10 Id validity and comparability Validity of ids describes the duration for which an id is not assigned to another object. Validity of graph and entity ids are only guaranteed for the duration of a query! Validity of entity ids is only guaranteed from the matching of an entity to the consumption of a query result. In other words: for the duration of the query. Validity, entity ids are guaranteed to not be re-used per graph for the duration of the query. These are the minimal lifetime guarantees mandated by Cypher 10. Implementations may provide extended validity guarantees as they see fit. Comparability of ids Graph and entity ids are suggested to be comparable values, i.e. can be compared with <, <=, =, >=, > 10
11 Query Processing Model
12 Query processor Query Processor = Query Processing Service (e.g. a single server or a cluster) G1 G2 G3 Catalog 12
13 Graph catalog A graph catalog maps graph names to graphs A qualified graph name is an (optionally dotted) identifier A graph name may be contextual; i.e. only work inside a specific server database... There are no further restrictions placed on graphs; e.g. graphs may be mutable or immutable exist only for a limited time (session, transaction,...) visible to all or only some of the users of the system... 13
14 Syntax for qualified graph names Qualified graph name syntax follows function name syntax Parts graph namespace (optional) graph name Syntax foo.bar.baz `foo`.`bar` `foo.bar` `foo.bar`.`baz.grok` (namespace foo.bar, graph baz.grok) Number of periods can be 0 to * Namespace and name separation is implementation-dependent Last part is always a suffix of the graph name 14
15 Working graph 1. A clause is always operating within the context of a working graph a. by reading from it b. by updating it 2. During the course of executing a query a. the working graph may be assigned by name (i.e. assigned to a graph from the catalog) b. the working graph may be assigned by graph projection (i.e. assigned by creating a new working graph) c. the working graph may be returned as a query result d. the graph id of the current working graph may be obtained using the graph() function 15
16 Initial working graph Determined by Query Processor This allows for implementation freedom Example This includes having no initial working graph Queries that need an initial working graph fail if no working graph has been set In Neo4j: Upon establishing a session via Bolt, an initial working graph to be used by subsequent queries is established (perhaps per user etc.) In CAPS: Cypher queries are always executed explicitly against a graph which implicitly becomes the initial working graph 16
17 Working graph operations Assign working graph by name (from catalog lookup) Access multiple graphs within one query Assign working graph by graph projection (next section) Consolidate data from one or more data sets into one graph Return (working) graph from query Construct temporary graph via multiple update queries (e.g. during interactive workflow) Return (export) graphs (e.g. system graph) 17
18 Working with multiple graphs
19 Select working graph // Set the working graph to the graph foo in the catalog for reading FROM foo // Set the working graph to the graph foo in the catalog for updating UPDATE foo // Change between reading and updating FROM GRAPH UPDATE GRAPH In any case, Does not consume the current cardinality Retains all variable bindings 19
20 Example: Reading from multiple graphs Which friends to invite to my next dinner party? [1] FROM social_graph [2] MATCH (a:person {ssn: $ssn})-[:friend]-(friend) [3] FROM salary_graph [4] MATCH (f:entity {ssn: friend.ssn})<-[:income]-(event) [5] WHERE $startdate < event.date < $enddate [6] RETURN friend.name, sum(event.amount) as incomes 20
21 Matching with multiple graphs FROM persons MATCH (a:person) FROM cars MATCH (b:car)-[:owned_by]->(a) // Does NOT match Updating multiple graphs FROM persons MATCH (a:person) UPDATE cars CREATE (b:car)-[:owned_by]->(a) // Error
22 Copy patterns How to copy data between graphs? FROM persons MATCH (a:person) UPDATE cars CREATE (b:car)-[:owned_by]->(x COPY OF a) // This works COPY OF node Copies labels, properties COPY OF rel Copies relationship type, properties (ignores start, end!) Also usable in matching: MATCH (COPY OF a)... 22
23 Returning a graph Cypher 10 queries may return a graph Three variations of consuming a graph returned by a query a. Deliver graph to client b. Pass graph to another query; e.g. within a subquery (not covered in these slides) c. Store graph in the catalog; i.e. registering a returned graph under a new name Delivering a result graph from the query to the client is always by value a. All nodes with their labels and properties b. All relationships with their relationship type, start node, end node, and their properties c. Result graph is completely independent from graphs managed by the query processor 23
24 Syntax for returning a graph // Returns the working graph... RETURN GRAPH // Removing the current cardinality while keeping the working graph... WITH GRAPH... // Return a graph from the catalog FROM graphname RETURN GRAPH 24
25 Graph operations
26 Graph operations Graph construction Common graph union Disjoint graph union
27 Graph construction Graph construction dynamically constructs a new working graph for querying, storing in the catalog, later updating using entities from other graphs (this is called cloning) Simple example MATCH (a)-[:knows {from: "Berlin"}]->(b) CONSTRUCT CLONE a AS x, b AS y CREATE (x)-[:met_in_berlin]->(y) RETURN GRAPH
28 Cloning nodes Take an original entity a and create a representative clone c in the constructed graph MATCH (a) CONSTRUCT CLONE a AS c // properties(a) = properties(c) AND labels(a) = labels(c) // but: a <> c because graph(a) <> graph(c)... Cloning the same original multiple times still only creates a single clone MATCH (root)-[:parent_of*]->(child) CONSTRUCT CLONE root, child // CLONE can shadow variables like WITH MERGE (root)-[:ancestor_of]->(child)...
29 Cloning relationships Cloning a relationship r implicitly clones startnode(r) and endnode(r) Cloning is powerful enough to reconstruct whole subgraphs! FROM car_owners MATCH (a:person {city: "Berlin"})-[r:OWNERS]->(c:Car) CONSTRUCT CLONE r // cars and their owners from berlin RETURN GRAPH
30 Clone paths and complex values Cloning a path p clones all nodes(p) and rels(p) More generally, cloning a value clones all contained entities! MATCH (a:person), (b:person) MATCH p = (a)-[:knows*]-(b) CONSTRUCT CLONE a, b, p CREATE (a)<-[:start]-(x:path {steps: size(p)})-[:end]->(b) RETURN GRAPH
31 Cloning graphs Clone all entities from given graphs into a new graph CONSTRUCT ON social_graph Clone all entities from working graph into new graph CONSTRUCT ON GRAPH Cloning a graph and a contained entity still only creates a single clone for the entity MATCH (a) WITH * LIMIT 1 CONSTRUCT ON GRAPH CLONE a AS x // creates only one x for the given a in the whole graph // (re-using clones created by CONSTRUCT ON GRAPH)
32 Finding clones Sometimes it may be necessary to find clones instead of creating them MATCH (x)-[:owns]->(y) CONSTRUCT CLONE x AS c CREATE (x)-[:owns]->(copy OF y)... WITH x, count(*) AS num_clones // lost x here! MATCH (CLONE OF x) // found the clone of x again...
33 General form of CONSTRUCT CONSTRUCT [ON GRAPH] [ON graph1, graph2,...] [CLONE expr [AS alias], variable,... * ] <updating clause 1> <updating clause 2>... WITH... WITH GRAPH RETURN... RETURN GRAPH
34 Provenance tracking So far, we've only looked at one step of graph construction. What about? [1] MATCH (a) // single node a [2] CONSTRUCT [3] CLONE a AS c // c <> a, it is a clone of a [4] WITH a, c [5] CONSTRUCT [6] CLONE a AS x, c AS y // x <> a is a clone of a, y <> c is a clone of c [7]... But x = y (i.e.they are the same clone). This is called provenance tracking. It's useful for updatable views and graph union.
35 Updatable views CONSTRUCT... // build the view... WITH GRAPH UPDATE GRAPH... // update the view...
36 Updates during graph construction General rule: Maintain logical consistency regarding provenance tracking CREATE Create in the constructed graph MERGE Merge in the constructed graph SET REMOVE Not allowed on clones (for now) [DETACH] DELETE Delete from the constructed graph
37 Updates after graph construction General rule: Only allow updates that can be propagated safely CREATE Not allowed MERGE SET REMOVE Not allowed Update base data [DETACH] DELETE Not allowed
38 Common graph union Clones of same original node are cloned, other entities are copied CONSTRUCT... RETURN GRAPH UNION CONSTRUCT... RETURN GRAPH
39 Disjoint graph union All entities (including clones) are copied (i.e. this breaks provenance tracking) CONSTRUCT... RETURN GRAPH UNION ALL CONSTRUCT... RETURN GRAPH
40 Updating the catalog
41 Catalog side-effects CREATE GRAPH foo // Create new graph 'foo' DELETE GRAPH foo // Delete graph 'foo' COPY foo TO bar // Copy graph 'foo' with schema RENAME foo TO bar // Rename graph 'foo' to 'bar' TRUNCATE foo // Remove data but keep schema in 'foo' 41
42 Create new base graph (snapshot) in catalog // create a new base graph in the catalog CREATE GRAPH mygraph // copy content of graph as new graph into the catalog CREATE GRAPH bar { <some query that returns a graph> } These are always top-level clauses; i.e. they may not be nested 42
43 Copy data from one base graph to another We can accomplish this by using DML and hand crafting the queries MATCH (a)-[r]->(b) UPDATE foo CREATE... MERGE... SET... 43
44 Schema updates Need to select the graph UPDATE foo CREATE CONSTRAINT... CREATE INDEX // Different keyword? 44
45 Catalog function catalog() catalog(graph(e)) Current working graph name in catalog or NULL Name of graph of e in catalog or NULL
46 Summary
47 Status Working on two CIPs Multiple graphs CIP (This talk, also: larger examples) Query composition CIP Features: views, nested subqueries, equivalence, more graph operations Future work: More elaborate updatable views, graph aggregation Goal is to finalize draft of multiple graphs CIP for next ocim Design heavily influenced by feedback from CAPS project and other implementation concerns
48 Feedback Please feedback by commenting on slides or CIP or opencypher implementers slack Thanks!
Multiple Graphs Updatable views & Choices
CIP2017-06-18 and related Multiple Graphs Updatable views & Choices Presentation at ocim 4 on May 22-24, 2018 Stefan Plantikow, Andrés Taylor, Petra Selmer (Neo4j) History Started working on multiple graphs
More informationCIP Configurable Pattern Matching Semantics. Stefan Plantikow, Mats Rydberg, Petra Selmer
CIP2017-01-18 Configurable Pattern Matching Semantics Stefan Plantikow, Mats Rydberg, Petra Selmer Current Semantics Outline Paths, Morphisms, and Walks Proposed Semantics Extensions Summary Current Semantics
More informationopencypher.org
Person Person Director name: Ed Jones age: 37 favcolor: blue FRIENDS since: 2003-05-12 qualified: good name: Peter Fry nick: Lil Pete bio:... MATCH (me:person)-[:friend]->(friend) WHERE me.name = "Frank
More informationThe Cypher Language 2017
DM32.2 2018-00145 Informational Paper The Cypher Language 2017 Presentation to the LDBC Query Language Task Force Neo Technology Cypher Language Group Date of original presentation 3 July 2017 Submitted
More informationProperty Graph Querying roadmap and initial scope
Property Graph Querying roadmap and initial scope Title Property Graph Querying roadmap and initial scope Authors Neo4j SQL working group Status Outline partial draft of initial working document on SQL
More informationOracle Database 11g: SQL and PL/SQL Fundamentals
Oracle University Contact Us: +33 (0) 1 57 60 20 81 Oracle Database 11g: SQL and PL/SQL Fundamentals Duration: 5 Days What you will learn In this course, students learn the fundamentals of SQL and PL/SQL
More informationCopyright 2016 Ramez Elmasri and Shamkant B. Navathe
Chapter 12 Outline Overview of Object Database Concepts Object-Relational Features Object Database Extensions to SQL ODMG Object Model and the Object Definition Language ODL Object Database Conceptual
More informationOracle Database: SQL and PL/SQL Fundamentals NEW
Oracle Database: SQL and PL/SQL Fundamentals NEW Duration: 5 Days What you will learn This Oracle Database: SQL and PL/SQL Fundamentals training delivers the fundamentals of SQL and PL/SQL along with the
More informationOracle Database: SQL and PL/SQL Fundamentals Ed 2
Oracle University Contact Us: Local: 1800 103 4775 Intl: +91 80 67863102 Oracle Database: SQL and PL/SQL Fundamentals Ed 2 Duration: 5 Days What you will learn This Oracle Database: SQL and PL/SQL Fundamentals
More informationRelational Model: History
Relational Model: History Objectives of Relational Model: 1. Promote high degree of data independence 2. Eliminate redundancy, consistency, etc. problems 3. Enable proliferation of non-procedural DML s
More informationSchema and Constraints
Schema and Constraints Mats Rydberg mats@neotechnology.com Schema in Cypher Cypher is schema-optional Fits well with heterogenous data Makes typing and query planning harder Does not fit well with many
More informationG-CORE: A Core for Future Graph Query Languages
G-CORE: A Core for Future Graph Query Languages Designed by the LDBC Graph Query Language Task Force Hannes Voigt hannes.voigt@tu-dresden.de http://bit.ly/gcorelanguage @LDBCouncil FOSDEM Graph Feb 3rd,
More informationCopyright 2016 Ramez Elmasri and Shamkant B. Navathe
CHAPTER 19 Query Optimization Introduction Query optimization Conducted by a query optimizer in a DBMS Goal: select best available strategy for executing query Based on information available Most RDBMSs
More informationFrom Cypher 9 to GQL: Conceptual overview of Multiple Named Graphs and Composable Queries
From Cypher 9 to GQL: Conceptual overview of Multiple Named Graphs and Composable Queries Petra Selmer, Alastair Green Neo4j Query Languages Standards and Research 1 Cypher 9 2 Cypher 9: A single, implicit
More information0. Overview of this standard Design entities and configurations... 5
Contents 0. Overview of this standard... 1 0.1 Intent and scope of this standard... 1 0.2 Structure and terminology of this standard... 1 0.2.1 Syntactic description... 2 0.2.2 Semantic description...
More informationChapter 11 Object and Object- Relational Databases
Chapter 11 Object and Object- Relational Databases Copyright 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 11 Outline Overview of Object Database Concepts Object-Relational
More informationT-SQL Training: T-SQL for SQL Server for Developers
Duration: 3 days T-SQL Training Overview T-SQL for SQL Server for Developers training teaches developers all the Transact-SQL skills they need to develop queries and views, and manipulate data in a SQL
More informationProgramming Languages Third Edition. Chapter 7 Basic Semantics
Programming Languages Third Edition Chapter 7 Basic Semantics Objectives Understand attributes, binding, and semantic functions Understand declarations, blocks, and scope Learn how to construct a symbol
More information5. Single-row function
1. 2. Introduction Oracle 11g Oracle 11g Application Server Oracle database Relational and Object Relational Database Management system Oracle internet platform System Development Life cycle 3. Writing
More informationCS558 Programming Languages
CS558 Programming Languages Fall 2016 Lecture 3a Andrew Tolmach Portland State University 1994-2016 Formal Semantics Goal: rigorous and unambiguous definition in terms of a wellunderstood formalism (e.g.
More informationMTA Database Administrator Fundamentals Course
MTA Database Administrator Fundamentals Course Session 1 Section A: Database Tables Tables Representing Data with Tables SQL Server Management Studio Section B: Database Relationships Flat File Databases
More informationReview -Chapter 4. Review -Chapter 5
Review -Chapter 4 Entity relationship (ER) model Steps for building a formal ERD Uses ER diagrams to represent conceptual database as viewed by the end user Three main components Entities Relationships
More informationCreating and Managing Tables Schedule: Timing Topic
9 Creating and Managing Tables Schedule: Timing Topic 30 minutes Lecture 20 minutes Practice 50 minutes Total Objectives After completing this lesson, you should be able to do the following: Describe the
More informationOracle Database: SQL and PL/SQL Fundamentals
Oracle University Contact Us: 001-855-844-3881 & 001-800-514-06-9 7 Oracle Database: SQL and PL/SQL Fundamentals Duration: 5 Days What you will learn This Oracle Database: SQL and PL/SQL Fundamentals training
More informationOracle Database 10g: Introduction to SQL
ORACLE UNIVERSITY CONTACT US: 00 9714 390 9000 Oracle Database 10g: Introduction to SQL Duration: 5 Days What you will learn This course offers students an introduction to Oracle Database 10g database
More informationMANAGING DATA(BASES) USING SQL (NON-PROCEDURAL SQL, X401.9)
Technology & Information Management Instructor: Michael Kremer, Ph.D. Class 6 Professional Program: Data Administration and Management MANAGING DATA(BASES) USING SQL (NON-PROCEDURAL SQL, X401.9) AGENDA
More informationCopyright 2007 Ramez Elmasri and Shamkant B. Navathe. Slide 27-1
Slide 27-1 Chapter 27 XML: Extensible Markup Language Chapter Outline Introduction Structured, Semi structured, and Unstructured Data. XML Hierarchical (Tree) Data Model. XML Documents, DTD, and XML Schema.
More informationIntroduction to Computer Science and Business
Introduction to Computer Science and Business The Database Programming with PL/SQL course introduces students to the procedural language used to extend SQL in a programatic manner. This course outline
More informationOracle Database: Introduction to SQL Ed 2
Oracle University Contact Us: +40 21 3678820 Oracle Database: Introduction to SQL Ed 2 Duration: 5 Days What you will learn This Oracle Database 12c: Introduction to SQL training helps you write subqueries,
More informationarxiv: v3 [cs.db] 9 Nov 2018
arxiv:1810.08755v3 [cs.db] 9 Nov 2018 A Property Graph Type System and Data Definition Language Mingxi Wu October 2018 Abstract We define a type system used to model property graph. This type system includes
More informationCS558 Programming Languages
CS558 Programming Languages Winter 2017 Lecture 4a Andrew Tolmach Portland State University 1994-2017 Semantics and Erroneous Programs Important part of language specification is distinguishing valid from
More informationTeiid Designer User Guide 7.5.0
Teiid Designer User Guide 1 7.5.0 1. Introduction... 1 1.1. What is Teiid Designer?... 1 1.2. Why Use Teiid Designer?... 2 1.3. Metadata Overview... 2 1.3.1. What is Metadata... 2 1.3.2. Editing Metadata
More informationWhat Every Xtext User Wished to Know Industry Experience of Implementing 80+ DSLs
What Every Xtext User Wished to Know Industry Experience of Implementing 80+ DSLs EclipseCon Europe 2016 2016-10-26 Roman Mitin Avaloq Evolution AG Allmendstrasse 140 8027 Zurich Switzerland T +41 58 316
More informationIan Kenny. November 28, 2017
Ian Kenny November 28, 2017 Introductory Databases Relational Algebra Introduction In this lecture we will cover Relational Algebra. Relational Algebra is the foundation upon which SQL is built and is
More informationOracle PLSQL. Course Summary. Duration. Objectives
Oracle PLSQL Course Summary Use conditional compilation to customize the functionality in a PL/SQL application without removing any source code Design PL/SQL packages to group related constructs Create
More informationQuerying Data with Transact-SQL
Querying Data with Transact-SQL General Description This course is designed to introduce students to Transact-SQL. It is designed in such a way that the first three days can be taught as a course to students
More informationProvenance Information in the Web of Data
Provenance Information in the Web of Data Olaf Hartig Humboldt-Universität zu Berlin http://olafhartig.de/foaf.rdf#olaf Provenance of a data item: information about the history 2 Provenance of a data item:
More informationPGQL: a Property Graph Query Language
PGQL: a Property Graph Query Language Oskar van Rest Sungpack Hong Jinha Kim Xuming Meng Hassan Chafi Oracle Labs June 24, 2016 Safe Harbor Statement The following is intended to outline our general product
More informationMobile MOUSe MTA DATABASE ADMINISTRATOR FUNDAMENTALS ONLINE COURSE OUTLINE
Mobile MOUSe MTA DATABASE ADMINISTRATOR FUNDAMENTALS ONLINE COURSE OUTLINE COURSE TITLE MTA DATABASE ADMINISTRATOR FUNDAMENTALS COURSE DURATION 10 Hour(s) of Self-Paced Interactive Training COURSE OVERVIEW
More informationMySQL for Beginners Ed 3
MySQL for Beginners Ed 3 Duration: 4 Days What you will learn The MySQL for Beginners course helps you learn about the world's most popular open source database. Expert Oracle University instructors will
More informationFedDW Global Schema Architect
UML based Design Tool for the Integration of Data Mart Schemas Dr. Stefan Berger Department of Business Informatics Data & Knowledge Engineering Johannes Kepler University Linz ACM 15 th DOLAP 12 November
More informationTopics. CSCI 403 Database Management DISTINCT. JOIN Clause 2/4/2019 DISTINCT JOINS. 12 Miscellaneous Topics
Topics CSCI 403 Database Management 12 Miscellaneous Topics This lecture is for stuff I forgot or didn t have time to cover so far Miscellaneous SELECT DISTINCT JOIN clause and outer joins SET operations
More informationIntroduction to Query Processing and Query Optimization Techniques. Copyright 2011 Ramez Elmasri and Shamkant Navathe
Introduction to Query Processing and Query Optimization Techniques Outline Translating SQL Queries into Relational Algebra Algorithms for External Sorting Algorithms for SELECT and JOIN Operations Algorithms
More informationQMF: Query Management Facility
A A Report - Figure 7... 1:26 ADD Sessions - Ending a Table Editor... 5:5 Adding Rows to a Table... 5:1 Adding Comments to an SQL Query... 3:5 ALIGN... 4:16 Arithmetic in Queries... 3:17 Available Tables
More information6232B: Implementing a Microsoft SQL Server 2008 R2 Database
6232B: Implementing a Microsoft SQL Server 2008 R2 Database Course Overview This instructor-led course is intended for Microsoft SQL Server database developers who are responsible for implementing a database
More informationCourse Prerequisites: This course requires that you meet the following prerequisites:
Developing MS SQL Server Databases This five-day instructor-led course introduces SQL Server 2014 and describes logical table design, indexing and query plans. It also focusses on the creation of database
More informationHeap, Variables, References, and Garbage. CS152. Chris Pollett. Oct. 13, 2008.
Heap, Variables, References, and Garbage. CS152. Chris Pollett. Oct. 13, 2008. Outline. Dynamic Allocation. Variables and Constants. Aliases and Problems. Garbage. Introduction. On Wednesday, we were talking
More informationDATABASE TECHNOLOGY - 1MB025
1 DATABASE TECHNOLOGY - 1MB025 Fall 2004 An introductory course on database systems http://user.it.uu.se/~udbl/dbt-ht2004/ alt. http://www.it.uu.se/edu/course/homepage/dbastekn/ht04/ Kjell Orsborn Uppsala
More informationCourse Outline Faculty of Computing and Information Technology
Course Outline Faculty of Computing and Information Technology Title Code Instructor Name Credit Hours Prerequisite Prerequisite Skill/Knowledge/Understanding Category Course Goals Statement of Course
More informationDATABASTEKNIK - 1DL116
1 DATABASTEKNIK - 1DL116 Spring 2004 An introductury course on database systems http://user.it.uu.se/~udbl/dbt-vt2004/ Kjell Orsborn Uppsala Database Laboratory Department of Information Technology, Uppsala
More informationOracle Developer Track Course Contents. Mr. Sandeep M Shinde. Oracle Application Techno-Functional Consultant
Oracle Developer Track Course Contents Sandeep M Shinde Oracle Application Techno-Functional Consultant 16 Years MNC Experience in India and USA Trainer Experience Summary:- Sandeep M Shinde is having
More informationWriting Queries Using Microsoft SQL Server 2008 Transact-SQL. Overview
Writing Queries Using Microsoft SQL Server 2008 Transact-SQL Overview The course has been extended by one day in response to delegate feedback. This extra day will allow for timely completion of all the
More informationCourse Modules for MCSA: SQL Server 2016 Database Development Training & Certification Course:
Course Modules for MCSA: SQL Server 2016 Database Development Training & Certification Course: 20762C Developing SQL 2016 Databases Module 1: An Introduction to Database Development Introduction to the
More informationLecture 3 SQL. Shuigeng Zhou. September 23, 2008 School of Computer Science Fudan University
Lecture 3 SQL Shuigeng Zhou September 23, 2008 School of Computer Science Fudan University Outline Basic Structure Set Operations Aggregate Functions Null Values Nested Subqueries Derived Relations Views
More informationDatabasesystemer, forår 2006 IT Universitetet i København. Forelæsning 9: Mere om SQL. 30. marts Forelæser: Esben Rune Hansen
Databasesystemer, forår 2006 IT Universitetet i København Forelæsning 9: Mere om SQL 30. marts 2006 Forelæser: Esben Rune Hansen Today s lecture Subqueries in SQL. Set operators in SQL. Security and authorization
More informationChapter No. 2 Class modeling CO:-Sketch Class,object models using fundamental relationships Contents 2.1 Object and Class Concepts (12M) Objects,
Chapter No. 2 Class modeling CO:-Sketch Class,object models using fundamental relationships Contents 2.1 Object and Class Concepts (12M) Objects, Classes, Class Diagrams Values and Attributes Operations
More informationUnderstanding Impact of J2EE Applications On Relational Databases. Dennis Leung, VP Development Oracle9iAS TopLink Oracle Corporation
Understanding Impact of J2EE Applications On Relational Databases Dennis Leung, VP Development Oracle9iAS TopLink Oracle Corporation J2EE Apps and Relational Data J2EE is one of leading technologies used
More informationQuick Guide to CAM Dictionaries
Quick Guide to CAM Dictionaries Building and using canonical XML components dictionaries for CAM Author: David RR Webber Chair OASIS CAM TC April, 2010 http://www.oasis-open.org/committees/cam 1 June,
More informationAdvanced Oracle Performance Troubleshooting. Query Transformations Randolf Geist
Advanced Oracle Performance Troubleshooting Query Transformations Randolf Geist http://oracle-randolf.blogspot.com/ http://www.sqltools-plusplus.org:7676/ info@sqltools-plusplus.org Independent Consultant
More informationQuerying Data with Transact SQL
Course 20761A: Querying Data with Transact SQL Course details Course Outline Module 1: Introduction to Microsoft SQL Server 2016 This module introduces SQL Server, the versions of SQL Server, including
More informationMidterm Review. Winter Lecture 13
Midterm Review Winter 2006-2007 Lecture 13 Midterm Overview 3 hours, single sitting Topics: Relational model relations, keys, relational algebra expressions SQL DDL commands CREATE TABLE, CREATE VIEW Specifying
More informationObject-Oriented Design
Object-Oriented Design Lecturer: Raman Ramsin Lecture 10: Analysis Packages 1 Analysis Workflow: Packages The analysis workflow consists of the following activities: Architectural analysis Analyze a use
More informationThe SQL database language Parts of the SQL language
DATABASE DESIGN I - 1DL300 Fall 2011 Introduction to SQL Elmasri/Navathe ch 4,5 Padron-McCarthy/Risch ch 7,8,9 An introductory course on database systems http://www.it.uu.se/edu/course/homepage/dbastekn/ht11
More informationWorking Draft, Extensions to C++ for Modules
Document Number: Date: 2017-03-19 Revises: N4637 Reply to: Gabriel Dos Reis Microsoft gdr@microsoft.com Working Draft, Extensions to C++ for Modules Note: this is an early draft. It s known to be incomplet
More informationData about data is database Select correct option: True False Partially True None of the Above
Within a table, each primary key value. is a minimal super key is always the first field in each table must be numeric must be unique Foreign Key is A field in a table that matches a key field in another
More informationTable of Contents. PDF created with FinePrint pdffactory Pro trial version
Table of Contents Course Description The SQL Course covers relational database principles and Oracle concepts, writing basic SQL statements, restricting and sorting data, and using single-row functions.
More informationRajiv GandhiCollegeof Engineering& Technology, Kirumampakkam.Page 1 of 10
Rajiv GandhiCollegeof Engineering& Technology, Kirumampakkam.Page 1 of 10 RAJIV GANDHI COLLEGE OF ENGINEERING & TECHNOLOGY, KIRUMAMPAKKAM-607 402 DEPARTMENT OF COMPUTER SCIENCE & ENGINEERING QUESTION BANK
More informationJoin (SQL) - Wikipedia, the free encyclopedia
페이지 1 / 7 Sample tables All subsequent explanations on join types in this article make use of the following two tables. The rows in these tables serve to illustrate the effect of different types of joins
More informationBasic Structure Set Operations Aggregate Functions Null Values Nested Subqueries Derived Relations Views Modification of the Database Data Definition
Chapter 4: SQL Basic Structure Set Operations Aggregate Functions Null Values Nested Subqueries Derived Relations Views Modification of the Database Data Definition Language 4.1 Schema Used in Examples
More informationDatabase Management System Dr. S. Srinath Department of Computer Science & Engineering Indian Institute of Technology, Madras Lecture No.
Database Management System Dr. S. Srinath Department of Computer Science & Engineering Indian Institute of Technology, Madras Lecture No. # 5 Structured Query Language Hello and greetings. In the ongoing
More informationWorking Draft, Extensions to C++ for Modules
Document Number: Date: 2017-02-03 Revises: N4610 Reply to: Gabriel Dos Reis Microsoft gdr@microsoft.com Working Draft, Extensions to C++ for Modules Note: this is an early draft. It s known to be incomplet
More informationDATABASE TECHNOLOGY - 1MB025
1 DATABASE TECHNOLOGY - 1MB025 Fall 2005 An introductury course on database systems http://user.it.uu.se/~udbl/dbt-ht2005/ alt. http://www.it.uu.se/edu/course/homepage/dbastekn/ht05/ Kjell Orsborn Uppsala
More informationStandard. Number of Correlations
Computer Science 2016 This assessment contains 80 items, but only 80 are used at one time. Programming and Software Development Number of Correlations Standard Type Standard 2 Duty 1) CONTENT STANDARD
More information1 Writing Basic SQL SELECT Statements 2 Restricting and Sorting Data
1 Writing Basic SQL SELECT Statements Objectives 1-2 Capabilities of SQL SELECT Statements 1-3 Basic SELECT Statement 1-4 Selecting All Columns 1-5 Selecting Specific Columns 1-6 Writing SQL Statements
More informationDifficult I.Q on Databases, asked to SCTPL level 2 students 2015
Do you know the basic memory structures associated with any Oracle Database. (W.r.t 10g / 11g / 12c)? The basic memory structures associated with Oracle Database include: System Global Area (SGA) The SGA
More informationDATABASE DESIGN I - 1DL300
DATABASE DESIGN I - 1DL300 Fall 2010 An introductory course on database systems http://www.it.uu.se/edu/course/homepage/dbastekn/ht10/ Manivasakan Sabesan Uppsala Database Laboratory Department of Information
More informationStefan Plantikow, Neo4j Stefan Plantikow, Neo4j
Stefan Plantikow, Neo4j 2 4 5 6 8 11 12 13 15 16 CYPHER 2017 CYPHER 2018 MATCH FROM GRAPH cities MATCH (city:city)-[:in]->(:country {name: "Germany"}) FROM GRAPH people MATCH (person)-[:lives_in]->(city)
More informationA Fast Review of C Essentials Part II
A Fast Review of C Essentials Part II Structural Programming by Z. Cihan TAYSI Outline Fixed vs. Automatic duration Scope Global variables The register specifier Storage classes Dynamic memory allocation
More informationQ&As Querying Data with Transact-SQL (beta)
CertBus.com 70-761 Q&As Querying Data with Transact-SQL (beta) Pass Microsoft 70-761 Exam with 100% Guarantee Free Download Real Questions & Answers PDF and VCE file from: 100% Passing Guarantee 100% Money
More informationAlgorithms for Query Processing and Optimization. 0. Introduction to Query Processing (1)
Chapter 19 Algorithms for Query Processing and Optimization 0. Introduction to Query Processing (1) Query optimization: The process of choosing a suitable execution strategy for processing a query. Two
More informationDB2 SQL Class Outline
DB2 SQL Class Outline The Basics of SQL Introduction Finding Your Current Schema Setting Your Default SCHEMA SELECT * (All Columns) in a Table SELECT Specific Columns in a Table Commas in the Front or
More informationOracle Syllabus Course code-r10605 SQL
Oracle Syllabus Course code-r10605 SQL Writing Basic SQL SELECT Statements Basic SELECT Statement Selecting All Columns Selecting Specific Columns Writing SQL Statements Column Heading Defaults Arithmetic
More informationGraph-based analysis of JavaScript source code repositories
Graph-based analysis of JavaScript source code repositories Gábor Szárnyas Graph Processing devroom @ FOSDEM 2018 JAVASCRIPT Latest standard: ECMAScript 2017 STATIC ANALYSIS Static source code analysis
More informationJavaScript. Training Offer for JavaScript Introduction JavaScript. JavaScript Objects
JavaScript CAC Noida is an ISO 9001:2015 certified training center with professional experience that dates back to 2005. The vision is to provide professional education merging corporate culture globally
More informationXML: Extensible Markup Language
XML: Extensible Markup Language CSC 375, Fall 2015 XML is a classic political compromise: it balances the needs of man and machine by being equally unreadable to both. Matthew Might Slides slightly modified
More informationNOSQL, graph databases & Cypher
NOSQL, graph databases & Cypher Advances in Data Management, 2018 Dr. Petra Selmer Engineer at Neo4j and member of the opencypher Language Group 1 About me Member of the Cypher Language Group Design new
More informationChapter 9: Relational DB Design byer/eer to Relational Mapping Relational Database Design Using ER-to- Relational Mapping Mapping EER Model
Chapter 9: Relational DB Design byer/eer to Relational Mapping Relational Database Design Using ER-to- Relational Mapping Mapping EER Model Constructs to Relations Relational Database Design by ER- and
More informationSql Server 'create Schema' Must Be The First Statement In A Query Batch
Sql Server 'create Schema' Must Be The First Statement In A Query Batch ALTER VIEW must be the only statement in batch SigHierarchyView) WITH SCHEMABINDING AS ( SELECT (Sig). I'm using SQL Server 2012.
More informationReview of the C Programming Language for Principles of Operating Systems
Review of the C Programming Language for Principles of Operating Systems Prof. James L. Frankel Harvard University Version of 7:26 PM 4-Sep-2018 Copyright 2018, 2016, 2015 James L. Frankel. All rights
More informationTable of Contents Chapter 1 - Introduction Chapter 2 - Designing XML Data and Applications Chapter 3 - Designing and Managing XML Storage Objects
Table of Contents Chapter 1 - Introduction 1.1 Anatomy of an XML Document 1.2 Differences Between XML and Relational Data 1.3 Overview of DB2 purexml 1.4 Benefits of DB2 purexml over Alternative Storage
More informationCS558 Programming Languages
CS558 Programming Languages Fall 2017 Lecture 3a Andrew Tolmach Portland State University 1994-2017 Binding, Scope, Storage Part of being a high-level language is letting the programmer name things: variables
More informationAdvanced Oracle SQL Tuning v3.0 by Tanel Poder
Advanced Oracle SQL Tuning v3.0 by Tanel Poder /seminar Training overview This training session is entirely about making Oracle SQL execution run faster and more efficiently, understanding the root causes
More informationChapter 3. Algorithms for Query Processing and Optimization
Chapter 3 Algorithms for Query Processing and Optimization Chapter Outline 1. Introduction to Query Processing 2. Translating SQL Queries into Relational Algebra 3. Algorithms for External Sorting 4. Algorithms
More informationListing of SQLSTATE values
Listing of values 1 of 28 5/15/2008 11:28 AM Listing of values The tables in this topic provide descriptions of codes that can be returned to applications by DB2 UDB for iseries. The tables include values,
More informationSt. MARTIN S ENGINEERING COLLEGE Dhulapally, Secunderabad
St. MARTIN S ENGINEERING COLLEGE Dhulapally, Secunderabad-00 014 Subject: PPL Class : CSE III 1 P a g e DEPARTMENT COMPUTER SCIENCE AND ENGINEERING S No QUESTION Blooms Course taxonomy level Outcomes UNIT-I
More informationCypher: An Evolving Query Language for Property Graphs
Cypher: An Evolving Query Language for Property Graphs Nadime Francis Université Paris-Est Leonid Libkin University of Edinburgh Stefan Plantikow Neo4j Alastair Green Neo4j Tobias Lindaaker Neo4j Mats
More informationGE PROBLEM SOVING AND PYTHON PROGRAMMING. Question Bank UNIT 1 - ALGORITHMIC PROBLEM SOLVING
GE8151 - PROBLEM SOVING AND PYTHON PROGRAMMING Question Bank UNIT 1 - ALGORITHMIC PROBLEM SOLVING 1) Define Computer 2) Define algorithm 3) What are the two phases in algorithmic problem solving? 4) Why
More informationReview of the C Programming Language
Review of the C Programming Language Prof. James L. Frankel Harvard University Version of 11:55 AM 22-Apr-2018 Copyright 2018, 2016, 2015 James L. Frankel. All rights reserved. Reference Manual for the
More informationMicrosoft SQL Server
Microsoft SQL Server Abstract This white paper outlines the best practices for Microsoft SQL Server Failover Cluster Instance data protection with Cohesity DataPlatform. December 2017 Table of Contents
More informationSQL Interview Questions
SQL Interview Questions SQL stands for Structured Query Language. It is used as a programming language for querying Relational Database Management Systems. In this tutorial, we shall go through the basic
More information