Talk:Navigational database
From Wikipedia, the free encyclopedia
I think this topic should be in lower-case, but I don't know how to change it without starting over.
[edit] thoughts
A few criticisms and thoughts.
Firstly, the title. I don't think it's the database that's navigational, I think it's the DML (database manipulation language). The same database can have more than one style of interface.
Secondly, the suggestion that SQL doesn't scale down seems both wrong and irrelevant.
The term is indeed due to Bachman, and it would be useful to quote some of the things he said. IIRC correctly it was a powerfully-argued paper and some retrospective analysis would be quite interesting.
Bringing the idea into the present with the reference to DOM is good, but the relevance needs to be stated.
Mhkay 22:04, 16 September 2005 (UTC)
A request for those DB experts out there: give us an example, in a pseudo code perhaps, of the difference between a navigational language, and a relational one.
Posit a database containing retail transactions, so the information one would expect to have is the items that could be purchased and their prices, and the items actually purhased, and the quantity purchased.
Thanks
Hacksaw 21:03:05, 2005Oct30 (UTC)
The article seems to be describing the scaling issue rather poorly. All relational databases have problems scaling up, not down. This is due to the search-based nature of their operation. Anytime you want to find something, even with a primary-key, the database engine has to search for it. This is because relational queries are based on the contents of a record, and the database has no foreknowledge of where any given content is. A navigational database, on the other hand, accesses things by unique address. Each record has such an address, and the database engine knows exactly where each address can be found. It only has to go to it -- no searching.
A simple analogy may help to explain this difference. Suppose you're looking for a particular person in a large city. You could:
-
- Try every house in the city (sequential scan); or
- Consult a telephone directory to locate their address (index scan); or
- You could go directly to their house, assuming you already know the address (navigational approach).
The last method is going to be the fastest as it doesn't involve any searching. Obviously, there's still the overhead involved in actually getting to the address, but all methods incur that same overhead eventually. The key point is that it doesn't matter how large or small the city is -- you can still locate the point of interest in constant time.
The first two methods are used by relational databases since they have no foreknowledge of where any given content is. As fast and efficient as modern RDBMSs may seem, they tend to become really sluggish as databases get very large and load increases. This is a direct result of the fact they have to run a search to find anything. Navigational databases don't have this problem, since they access things by their direct address (i.e. they know in advance where things are).
Mathematically speaking, relational systems exhibit a complexity of O(n)
for sequential scans and O(log n)
for indexes. Their search performance drops off as things get bigger. Navigational databases have a complexity of O(1)
. Their performance remains fairly constant as sizes increase.
Siggimoo 21:13, 3 October 2006 (UTC)
[edit] Deconstruction
Would I be incorrect in thinking that a Wiki, and, indeed, the entire WWW is a navigational database? It has dynamic content, and you can get from point A to point F by following links and navigating through points B, C, D and E.
[edit] Answer
This is actually a very good analogy. The relational approach is using Google to find pages. This is what differentiates the two models. Relational is about matching content to find relationships (e.g. find all orders whose customer ID equals x). Navigational is about jumping directly to specific records (e.g. get these specific orders).