IBM Business System 12

related topics
{math, number, function}
{system, computer, user}
{company, market, business}
{work, book, publish}
{theory, work, human}
{law, state, case}
{game, team, player}
{city, large, area}

Business System 12, or simply BS12, was one of the first fully relational database management systems, designed and implemented by IBM's Bureau Service subsidiary at the company's international development centre in Uithoorn, Netherlands. Programming started in 1978 and the first version was delivered in 1982. It was never widely used and essentially disappeared soon after the division was shut down in 1985, possibly because IBM and other companies settled on SQL as the standard.

BS12's lasting contribution to history was the use of a new query language based on ISBL, created at IBM's UK Scientific Centre. Developers of the famous System R underway in the US at the same time were also consulted on certain matters concerning the engine, but the BS12 team rejected SQL unequivocally, being convinced that this apparently unsound and difficult-to-use language (which at that time was also relationally incomplete) would never catch on.

BS12 included a number of interesting features that still have yet to appear on most SQL-based systems, some a consequence of following the ISBL precedent, others due to deliberate design. For instance, a view could be parameterised and parameters could be of type TABLE. Thus, a view could in effect be a new relational operator defined in terms of the existing operators. Codd's DIVIDE operator was in fact implemented that way.

Another feature that could have easily been included in SQL systems was the support for update operations on the catalog tables (system tables describing the structure of the database, as in SQL). A new table could be created by inserting a row into the TABLES catalog, and then columns added to it by inserting into COLUMNS.

In addition, BS12 was way ahead of SQL in supporting user-defined functions and procedures using a computationally complete sublanguage, triggers, and a simple "call" interface for use by application programs, all in its very first release in 1982.

Example

Sample query from BS12 article on System R website for determining which departments are over their salary budgets:

 T1 = SUMMARY(EMP, GROUP(DEPTNUM), EMPS=COUNT, SALSUM=SUM(SALARY))
 T2 = JOIN(T1, DEPT) 
 T3 = SELECT(T2, SALSUM > BUDGET)

Note the "natural join" on the common column, DEPTNUM. Although some SQL dialects support natural joins, for familiarity, the example will show only a "traditional" join. Here is the equivalent SQL for comparison:

See also

External links

Full article ▸

related documents
Lint (software)
Uniform Resource Locator
Disassembler
Denormal number
Lazy initialization
JUnit
Greibach normal form
Galois group
Context-sensitive language
Essential singularity
Direct sum of groups
Identity function
Disjoint sets
Derivative of a constant
Chart parser
Sedenion
Recursive language
Sigmoid function
Markov process
Endomorphism ring
RC5
Harmonic analysis
Z notation
Data element
List of Fourier-related transforms
Hilbert's Nullstellensatz
Ring homomorphism
Co-NP
Sieve of Eratosthenes
Water, gas, and electricity