Microsoft SQL Server je systém pro správu relačních databází (RDBMS) vyvinutý společností Microsoft Corporation . Hlavním používaným dotazovacím jazykem je Transact-SQL , vytvořený společně společnostmi Microsoft a Sybase . Transact-SQL je implementace standardu ANSI / ISO pro strukturovaný dotazovací jazyk ( SQL ) s rozšířeními. Používá se pro práci s databázemi různých velikostí od osobních až po rozsáhlé podnikové databáze; konkuruje ostatním DBMS v tomto segmentu trhu.
Verze | Rok | název | krycí jméno |
---|---|---|---|
1.0 ( OS/2 ) | 1989 | SQL Server 1.0 (16bit) | Filipi |
1.1 ( OS/2 ) | 1991 | SQL Server 1.1 (16bit) | Pietro |
4.21 ( WinNT ) | 1993 | SQL Server 4.21 | SQLNT |
6.0 | 1995 | SQL Server 6.0 | SQL95 |
6.5 | 1996 | SQL Server 6.5 | Hydra |
7,0 | 1998 | SQL Server 7.0 | Sfinga |
- | 1999 | Nástroje OLAP pro SQL Server 7.0 | Palato mánie |
8,0 | 2000 | SQL Server 2000 | Shiloh |
8,0 | 2003 | SQL Server 2000 64-bit | Svoboda |
9,0 | 2005 | SQL Server 2005 | Yukon |
10,0 | 2008 | SQL Server 2008 | Katmai |
10.25 | 2010 | Azure SQL DB | Cloudová databáze nebo CloudDB |
10,50 | 2010 | SQL Server 2008 R2 | Kilimandžáro (aka KJ) |
11.0 | 2012 | SQL Server 2012 | Denali |
12.0 | 2014 | SQL Server In-Memory OLTP | Hekaton |
13,0 | 2016 | SQL Server 2016 | |
14.0 | 2017 | SQL Server 2017 | |
15,0 | 2019 | SQL Server 2019 |
Rozvoj technologií klient-server ve druhé polovině 80. let byl dán rozvojem dvou klíčových oblastí, které se aktivně rozvíjely od konce 70. let: osobních počítačů na jedné straně a počítačových sítí na straně druhé. Dlouhou dobu byly DBMS dostupné pouze pro sálové počítače a teprve díky zvýšení výkonu procesorů pro domácí počítače a minipočítače začali vývojáři DBMS (jako Oracle ) vytvářet odpovídající verze svých produktů. Jedním z prvních RDBMS pro PC byl Oracle v3 , vydaný v roce 1983. V té době je pár majitelů PC využívalo hlavně pro vývoj aplikací a testování [1] .
Jednou z klíčových fází vývoje DBMS byl rok 1986. Do této doby se objevilo několik dalších vývojových společností DBMS, jednou z nejpozoruhodnějších z nich byla Sybase , založená o dva roky dříve. V roce 1986 začala společnost Sybase spojovat inteligentní pracovní stanice (typicky navržené společnostmi Sun Microsystems nebo Apollo Computer ) s databázovými servery (navrženými například společností Oracle). Samotná technologie klient-server přitom umožnila oddělit moduly zpracování informací (tzv. back end) od modulů rozhraní (tzv. frontend). S ohledem na neustálý nárůst penetrace počítačových sítí se poskytovatelé řešení přesunuli k úkolu distribuovat další úkoly (například formátování zpráv, kontrola dat atd.) mezi síťovými pracovními stanicemi, přičemž server ponechal pouze úkoly, které vyžadují centralizovaný řešení (ukládání a ochrana dat, tok provádění optimalizačních dotazů atd.) [1] .
Na přechodu od hierarchických k relačním databázím se významně podíleli sami vývojáři DBMS . V této době tedy IBM již postupně převádělo své zákazníky z hierarchických DBMS (jako např. IMS ) na DB2 a SQL / DS RDBMS . Nový DBMS, ačkoliv je v rychlosti nižší než IMS, jej předčil ve snadném programování a údržbě. Dodávky DB2 rychle překonaly očekávání a v prvním roce prodeje získaly významný podíl na trhu. V září 1986 Gupta Technologies představila svůj vývoj SQL Base, který obsahoval koncept databázového serveru pro síťová PC. Gupta byl také jedním z prvních, který implementoval transparentní přístup k sálovým počítačům IBM provozujícím na nich DB2 a poskytoval přímý přístup k tam uloženým datům bez nutnosti stahování souborů nebo tabulek na pracovní stanici uživatele [1] .
Do konce roku 1986 se používání jazyka SQL jako hlavního jazyka pro práci s daty v DBMS stalo téměř univerzálním. IBM, Oracle, Sybase a Gupta používaly podobnou syntaxi SQL k odesílání zpráv z frontendu na zadní konec DBMS, což umožnilo kombinaci klientských a serverových částí od různých dodavatelů. Ve stejném roce schválil American National Standards Institute verzi jazyka SQL jako mezinárodní standard pro zpracování dat, což ohrožovalo blaho DBMS, které nepodporovaly jazyk SQL. Takže například společnost Cullinet , přestože oznámila podporu jazyka SQL ve své DBMS pro minipočítače, ztratila svůj podíl na trhu DBMS kvůli zpoždění v implementaci a ustoupila IBM a jejímu produktu DB2 [1] .
V tomto okamžiku byl veškerý vývoj společnosti Microsoft zaměřen výhradně na domácí počítače a jeho nejziskovějším produktem byl operační systém MS-DOS . Zpracování klient-server dat na osobních počítačích do roku 1986 teprve získalo popularitu a z tohoto důvodu bylo mimo zájmy společnosti . O rok dříve, v červnu 1985, podepsaly IBM a Microsoft smlouvu o společném vývoji ( angl. Joint Development Agreement , zkr. JDA), obsahující pouze obecná ustanovení pro budoucí spolupráci. V srpnu 1985 byla JDA doplněna dokumentem s kódovým označením „Phase II“ ( angl. Phase II ), obsahující plány rozvoje OS/2 . V té době byl produkt uveden jako CP/DOS ( Eng. Control Program/DOS v souladu se zásadami IBM pro pojmenování mainframových produktů, zatímco Microsoft uvedl produkt jako DOS 5. Koncem roku 1986 a začátkem roku 1987 byl projekt oficiálně přejmenován na OS /2 za to, že se název podobá řadě počítačů IBM PS/2 [2] .
2. dubna 1987 byl oznámen OS/2 (verze 1.0 měla být podle tiskové zprávy vydána v prvním čtvrtletí roku 1988, ale nakonec byla vydána v prosinci 1987) [2] . Podle plánů oznámených v dubnu 1987 plánovala IBM přidat funkcionalitu DBMS do OS / 2 a pomocí konceptu vyvinutého společností Gupta Technologies, který spočíval v odesílání dotazů SQL hostiteli prostřednictvím síťových směrovačů osobním počítačem a vracení pouze výsledků provedení jako žádost o odpověď. Zatímco prodejci OS již několik let začleňují do svých produktů některé funkce DBMS, myšlenka IBM implementovat plnohodnotný DBMS zabudovaný do operačního systému vedla mnoho manažerů k přehodnocení jejich pohledu na PC jako vhodnou platformu pro implementaci multi -uživatelské aplikace a koncept klienta -server technologie [1] .
Krátce po oznámení IBM také oznámilo speciální vylepšenou verzi tohoto OS – OS / 2 Extended Edition. Tato verze měla být dodávána s OS/2 Database Manager a několika dalšími síťovými a serverovými řešeními. Přestože byl Database Manager více orientován na sálové počítače než na osobní počítače, IBM mohla přesto nabídnout kupujícím lepší produkt než konkurence na základě jejich společného vývoje. Potřeba vlastního vývoje v oblasti správy databází se pro společnost Microsoft stala zřejmou a velmi relevantní.
Aby Microsoft vyřešil tento problém, obrátil se na Sybase , který v té době ještě nevydal komerční verzi svého produktu DataServer (stalo se tak o něco později, v květnu 1987, a to pouze pro pracovní stanice Sun se systémem UNIX ). Důvodem odvolání bylo, že pre-release verze DataServeru, i když se nejednalo o produkt určený pro široké použití, nicméně díky implementaci nových nápadů (zejména architektura klient-server) získala nová DBMS velmi dobré recenze. V důsledku takové dohody by společnost Microsoft získala výhradní práva na verzi DataServeru pro OS / 2 a všechny OS vyvinuté samotnou společností Microsoft a Sybase by kromě licenčních poplatků od společnosti Microsoft získala přístup k části obsazeného trhu. produkty společnosti Microsoft (včetně nového OS / 2) . Vzhledem k tomu, že výkon domácích počítačů je nízký, považovala společnost Sybase tento segment trhu za základ pro následný prodej svého produktu pro výkonnější systémy na bázi UNIX, zejména proto, že společnost Microsoft díky své dobře zavedené distribuční síti mohla zajistit výrazně vyšší prodeje DataServer než samotný Sybase. 27. března 1987 podepsali prezident Microsoftu John Shirley a spoluzakladatel Sybase Mark Hofmann (který byl v té době také prezidentem společnosti) dohodu.
V té době zaujímal lví podíl na trhu PC DBMS Ashton-Tate se svým dBASE . Vzhledem k tomu, že DataServer měl mírně odlišné schopnosti ve srovnání s dBASE, nebyly tyto produkty považovány za potenciální konkurenty. To umožnilo Microsoftu uzavřít dohodu s Ashton-Tate o propagaci DataServeru v komunitě uživatelů dBASE.
13. ledna 1988 se v New Yorku konala tisková konference oznamující spojenectví mezi Ashton-Tate a Microsoft za účelem vývoje nového produktu nazvaného Ashton-Tate/Microsoft SQL Server. Ve stejný den byla vydána společná tisková zpráva oznamující nový produkt založený na vývoji Sybase. Předběžným datem uvedení produktu na trh byla druhá polovina roku 1988 [3] . Pokud jde o role společností ve vývoji a propagaci produktů, podle tiskové zprávy měla být Ashton-Tate odpovědná za dohled nad vývojem databází (a také za poskytování vlastního vývoje v této oblasti), zatímco Microsoft dostal podobnou roli v technologie pro práci v lokálních sítích. Po vydání SQL Serveru měl Ashton-Tate licencovat produkt od Microsoftu a prodávat po celém světě (jak jako samostatný produkt, tak v balíčku s budoucími verzemi dBASE) a Microsoft bude dodávat produkt hardwarovým OEM [4] .
SQL Server byl již okamžitě umístěn jako relační DBMS s podporou jazyka SQL a schopností pracovat přes lokální síť. Kromě toho bylo oznámeno, že SQL Server je kompatibilní s dBASE nebo jiným softwarem pro pracovní stanice. Velký důraz byl kladen na architekturu klient-server produktu, díky čemuž jsou funkční funkce klientské aplikace ( angl. front-end ), ve které uživatelé uvidí potřebná data, a serverové části ( angl. back- end ), ve kterém budou tato data uložena. Ashton-Tate a Microsoft také oznámili „tři hlavní inovace v technologii relačních databází“: podporu uložených procedur sestavených SQL Serverem, což „výrazně zrychlí“ získávání dat a zachová integritu dat při práci v prostředí s více uživateli. Druhou novinkou byla stálá dostupnost jádra (bez přerušení uživatelských akcí) pro administrativní úkoly, jako je vytváření záložních kopií dat (záloha) a jejich obnova. Třetí novinkou byla podpora technologie, která funguje jako most mezi online systémy pro zpracování transakcí a databázemi na PC. Samotný SQL Server měl být založen na architektuře „otevřené platformy“, která by vývojářům softwaru třetích stran umožnila vytvářet aplikace využívající síťové a víceuživatelské schopnosti SQL Serveru. Bill Gates , který byl v té době předsedou představenstva Microsoftu, zároveň označil síť za „nejdůležitější výpočetní platformu pro nové a inovativní aplikace“. SQL Server musel běžet na libovolných síťových serverech založených na OS/2, včetně Microsoft OS/2 LAN Manaqer a IBM LAN Server, a musel komunikovat s pracovními stanicemi s OS/2, PC-DOS nebo MS-DOS [4] .
Ashton-Tate viděl SQL Server jako příležitost převzít trh s databázemi domácích počítačů, aniž by opustil vývoj dBASE. Oba produkty měly být zároveň nabízeny firemním zákazníkům. Microsoft počítal s podporou SQL Serveru jako základu pro transačně orientované systémy, včetně různých účetních systémů, knihoven dokumentů, systémů pro řízení výzkumu a dalších. K propagaci nového produktu obě společnosti naplánovaly řadu různých seminářů a konferencí, z nichž první byla konference Microsoft Advanced Network Development Conference naplánovaná na 30. března až 1. dubna v San Franciscu a na 13. až 15. dubna v New Yorku [4] .
Společnost Sybase, přestože se její jméno v názvu nového produktu neobjevilo, byla ve skutečnosti hlavním vývojářem celé trojice společností. Příspěvek Microsoftu byl na druhou stranu docela malý. V Sybase byl již vytvořen malý tým, který portoval engine DataServer na OS/2 a také portoval klientské rozhraní DB-Library na MS-DOS a OS/2. Společnost Microsoft byla zodpovědná za testování a řízení projektů a také vyvinula několik dalších nástrojů, které usnadnily instalaci a správu SQL Server 1.0.
Nový produkt byl koncipován jako port Sybase DataServer na OS/2, který bude prodávat Microsoft i Ashton-Tate. Souběžně s tím měla být nová verze dBASE IV od Ashton-Tate zpřístupněna také ve verzi na straně serveru, což umožňuje používat jazyk dBASE IV a vývojové nástroje k vytváření klientských aplikací, které by mohly pracovat s novým SQL Serverem. Nový model klient-server měl dBASE umožnit dosáhnout nové úrovně výkonu a dát příležitost pracovat s daty mnohem většímu počtu uživatelů, než umožňoval tehdejší běžný model sdílení souborů .
Ashton-Tate/Microsoft SQL Server Beta byla vydána 31. října 1988 jako součást sady SQL Server Network Developer's Kit (zkr. MDK). Tato sada obsahovala předběžnou verzi SQL Server, dokumentaci, knihovny API pro SQL Server a Microsoft OS/2 LAN Manager . Softwarové knihovny byly navrženy tak, aby kompilovaly ( pomocí vlastního kompilátoru C od společnosti Microsoft ) aplikace MS-DOS , Windows nebo OS/2 pro spouštění SQL Serveru přes místní síť. Sada byla prodávána výhradně pro vývoj softwaru, ale byla dodávána se speciálním kupónem, který zákazníkům umožňoval upgrade na plnou verzi SQL Server poté, co byla vydána [5] .
MDK prodával přímo Ashton-Tate v USA a Kanadě (a Microsoft v USA) za zvýhodněnou cenu. Microsoft také nabízel výraznou slevu vývojářům, kteří si již zakoupili Microsoft OS/2 Software Developer's Kit nebo se zúčastnili jedné z Microsoft Advanced Network Development Conference. Na druhé straně Ashton-Tate také nabídl podobnou slevu vývojářům, kteří se v roce 1988 zúčastnili Ashton-Tate Developer's Conference [5] .
MDK měl spoustu chyb a nedostatků, přesto fungoval na domácích počítačích (s procesorem např. Intel 80286 s frekvencí 10 MHz, 6 MB RAM a 50 MB pevný disk ).
29. dubna 1989 začal oficiální prodej Ashton-Tate/Microsoft SQL Server 1.0. Členové týmu SQL Server měli na speciální týmové certifikační akci v .Torrance ) [3] trička s nápisem „Ashton-Tate SQL Server: On-Time and Proud of It“ .
Testy časopisu Infoworld ukázaly, že Ashton-Tate/Microsoft SQL Server 1.0, i když běží na síti s 24 pracovními stanicemi, se vyrovnal se zátěží rychleji než běžná víceuživatelská databáze (v té době nejběžnější typ databáze) a když pomocí uložených procedur bylo možné dosáhnout rychlosti odezvy méně než dvě sekundy. Novináři také zaznamenali snadnost a pohodlí psaní testovacího kódu .
Profilový tisk se o novince vyjádřil vcelku pozitivně, nicméně prodeje byly velmi nízké. Prodej OS/2 byl také zklamáním, protože mnoho uživatelů nebylo ochotno přejít z MS-DOS na OS/2. Obrázek dokreslovala schopnost vytvářet aplikace SQL Server pouze v jazyce C, protože slíbená dBASE IV Server Edition od Ashton-Tate byla zpožděna a situace byla podobná s nástroji SQL Server třetích stran. . Kromě toho hrála roli také konkurence: na trhu DBMS pro platformy PC již v té době existovaly XDB od XDB, SQLBase od Gupta Technologies a OS/2 Extended Edition (v režimu jednoho uživatele) od IBM [3] .
Do roku 1990 se situace nezlepšila. Plány na společnou propagaci produktu, která by SQL Serveru poskytla oporu ve velké komunitě vývojářů dBASE, ztroskotaly. I přes odložení vydání desktopové verze dBASE IV (vydáno v roce 1989) stále obsahovala velké množství chyb, kvůli kterým si vysloužila špatnou pověst. Server Edition, který měl zjednodušit vývoj vysoce výkonných aplikací pro SQL Server, nikdy nevyšel. Vývoj aplikací v dBASE pro SQL Server se stal výzvou, protože vývoj jednouživatelské aplikace orientované na zápis se zásadně lišil od vývoje víceuživatelských aplikací, které stále musely řešit problémy s paralelním prováděním úloh, správnou paralelní práci s daty a nízkou propustností pak lokální sítě. První pokusy o propojení nástrojů dBASE s SQL Serverem vedly k neefektivní spolupráci těchto produktů (například dotazování na data řádek po řádku se stalo problémem a kurzory s libovolným přechodem po řádcích tehdy neexistovaly).
Výsledkem je, že společnost Ashton-Tate, která dominovala na trhu domácích PC databází o dva roky dříve, nyní bojuje o přežití, což ji přinutilo přejít zpět na svůj vlajkový produkt dBASE. Microsoft mezitím spustil OS/2 LAN Manager pod svou vlastní značkou (když bylo původně plánováno dodávat pouze OEM verze) a potřeboval SQL Server, aby pomohl položit základy pro vývoj klient/server nástrojů, které by mohly spolupracovat s Microsoftem. Manager a Microsoft OS/2. To vše vedlo k rozhodnutí zastavit společnou propagaci SQL Serveru, načež byl tento produkt mírně změněn a prezentován jako Microsoft SQL Server.
Ještě před vydáním verze 1.1 představitelé Microsoftu (na rozdíl od nezávislých analytiků) předpovídali prudký nárůst prodejů nové verze produktu, ale jejich naděje se nenaplnily. Microsoft SQL Server 1.1 byl vydán v srpnu 1990 jako aktualizace a náhrada za Ashton-Tate/Microsoft SQL Server 1.0 prodaný v roce 1989 [6] . V době vydání verze 1.1 Microsoft stále nepovažoval SQL Server za produkt schopný sám o sobě generovat zisk – proto byl pouze jednou z aplikací pro LAN Manager (Microsoft dokonce začal vytvářet prodejní kanály pro partnery pro oba produkty, ačkoli se nikdy předtím nezabýval maloobchodními LAN řešeními ). Pozitivní roli mělo sehrát brzké vydání klientských aplikací ( anglické frontendy ) od Borland a DataEase International , zejména proto, že se v průběhu roku očekávalo několik dalších podobných řešení (v té době byla podmíněně nazývána „druhá generace"). Zároveň však byla neméně důležitá součást SQL Serveru – balíček nainstalovaných protokolů – stále ve vývoji. TCP/IP verze Net-Library, první z tohoto balíčku, byla stále ve fázi alfa testování, zatímco její verze DEC-NET a SPX byly obecně ve vývoji bez oznámených dat vydání. Kromě toho zjevná složitost výpočetní techniky klient-server a stále pokračující vývoj serverových a klientských aplikací znamenaly, že rané prodeje SQL Server 1.1 byly velmi nízké [7] .
Funkce SQL Server 1.1 byly obecně podobné funkcím verze 1.0, ale nová verze obsahovala mnoho oprav chyb, které se objevily ve verzi 1.0. Kromě toho SQL Server 1.1 také podporoval výměnu informací s novou klientskou platformou - Microsoft Windows 3.0, která se začala dodávat v květnu 1990 a způsobila hmatatelnou reakci v počítačovém průmyslu. SQL Server 1.1 byl nyní mnohem snadněji konfigurovatelný pro práci s LAN Manager a byla také vylepšena instalace produktu pro sítě Novell a jako samostatný systém pro vývoj softwaru. Balíček obsahoval Základní knihovnu pro SQL Server, což bylo rozhraní mezi SQL Serverem a Microsoft Basic Professional Development System. Díky této knihovně byla poprvé přidána podpora pro tento jazyk [6] .
Klient SQL Server 1.1 mohl pracovat s novou verzí DB-Library, rozhraní mezi klientem a SQL Serverem, která byla distribuována některým vývojářům měsíc před vydáním nové verze samotného SQL Serveru. Nová verze DB-Library byla téměř kompletně přepsaná verze předchozí verze, díky čemuž začala zabírat pouze 40 KB místo předchozích 80 KB a zbylo více paměti pro DOS aplikace na klientských systémech (nyní vývojář obdržel 250 KB pro jeho aplikaci namísto předchozích 50 KB získaných pomocí statických DB-knihoven dodaných se serverem SQL Server 1.0). Architektura připojovacího protokolu v DB-Library byla nyní schopna komunikovat s klienty na DOS, Windows a OS/2 a také podporovala přístup k Sybase SQL Server na jiných platformách. Podle informací od samotných společností Microsoft a Sybase však byly tyto ovladače stále v aktivním vývoji [6] .
Licencování SQL Server 1.1 zahrnovalo následující možnosti [6] :
Schopnost pracovat s klientskými systémy SQL Server 1.1 od různých výrobců umožnila těmto výrobcům prodávat Microsoft SQL Server 1.1 spolu s jejich vlastním vývojem. Prvními členy programu SQL Business Partner Program jsou Ashton-Tate, Blyth Software, Dataease International, Revelation Technologies a Sybase. Tyto společnosti mohly realizovat prodej prostřednictvím krátce předtím vytvořené speciální distribuční sítě ( anglicky Microsoft Network Specialist channel ), jejímž hlavním úkolem do té doby byl prodej Microsoft LAN Manageru, nebo prodávat přímo koncovým uživatelům. Z těchto pěti partnerů mohl v době vydání nové verze nabídnout uživatelům klientskou část pro SQL Server - SQL Link pro Framework III pouze Ashton-Tate (celkem bylo tehdy na trhu dostupných asi 40 takových řešení čas). Společnost Dataease International oznámila, že její řešení Dataease SQL 1.0 bude možné zakoupit od 14. září téhož roku. Podle Microsoftu zbývající dva partneři plánovali vydat svá řešení (MS-SQL Server Bond pro Advanced Revelation od Revelation Technologies a Omnis 5 od Blyth Software) ve třetím čtvrtletí téhož roku. Ashton-Tate dBase IV 1.1 Server Edition, která měla podporovat SQL Server, byla očekávána před koncem roku 1990. V prvním čtvrtletí roku 1991 měla být uvolněna serverová rozhraní pro podporu dalších klientských systémů dBase, jmenovitě Arago Dbxl a Arago Quicksilver od Wordtech Systems [6] .
Ve třetím čtvrtletí roku 1990 byly uvolněny Access SQL (od Software Products International) a Q+E (od Pioneer Software), které poskytují přímou komunikaci mezi Microsoft Excel a SQL Server [6] . Q+E konkrétně umožnilo v podstatě všem aplikacím Windows (včetně těch pro Windows 3.0), které mohou pracovat s připojeními Dynamic Data Exchange , také komunikovat se serverem SQL. Z pohledu uživatele umožnila Q+E 2.5 uživatelům prohlížet, slučovat a třídit informace v databázích bez psaní příslušných SQL dotazů. A protože volání DDE byla zabudována do samotné aplikace Q+E, uživatelé jako Excel mohli provádět následné zpracování dat [8] .
Počátkem roku 1991 mohly se serverem SQL pracovat desítky softwarových produktů třetích stran. Významnou roli v tom sehrála podpora SQL Serveru pro dynamické knihovny implementovaná ve Windows 3.0 a tato podpora byla v SQL Serveru implementována téměř od samého počátku prodeje Windows 3.0. Díky tomu začal Microsoft SQL Server systematicky získávat přední místo mezi DBMS zaměřenými na platformu Windows. I přes zlepšení situace však přetrvával problém s dostupností nástrojů, které podporují vývoj v jiných jazycích než C.
Obecně platí, že politika včasné a plné podpory aplikací pro Windows 3.0 byla také zodpovědná za úspěch Microsoft SQL Server a kromě toho zjevný úspěch Windows jako platformy také vyžadoval změny v SQL Serveru i samotném Microsoftu. Zejména tým Microsoftu, který se zabýval portováním cizího produktu, postupně přešel k plnohodnotnému testování a projektovému řízení a následně k vývoji vlastních nástrojů pro usnadnění instalace a správy SQL Serveru. Ale i když Microsoft dodal svůj vlastní klientský software a utility, softwarové knihovny a nástroje pro správu s SQL Server 1.1, SQL Server engine byl stále napsán Sybase, zatímco Microsoft neměl ani přístup ke zdrojovému kódu . Tento model stanovil, že za účelem splnění jakýchkoli požadavků na změnu funkčnosti SQL Serveru (včetně oprav chyb) musel Microsoft tyto požadavky odeslat společnosti Sybase, která provedla příslušné změny. Microsoft se na druhou stranu snažil vytvořit plnohodnotný a nezávislý tým podpory SQL Serveru, pro který najal inženýry, kteří měli zkušenosti s prací s databázemi. Bez přístupu ke zdrojovému kódu však tým čelil neschopnosti vyřešit kritické problémy zákaznické podpory pro produkt. Kromě toho se vyskytl problém se spoléháním Microsoftu na Sybase při opravě chyb v produktu, což vedlo k tomu, že Sybase nebyl dostatečně rychlý, aby opravoval kritické chyby nárokované Microsoftem.
Počátkem roku 1991 Microsoft a Sybase dosáhly dohody, podle níž měl první z nich přístup ke zdrojovému kódu SQL Serveru, ale pouze v režimu čtení (tj. bez možnosti provádět změny). Tato dohoda umožnila týmu podpory produktu (takzvaná skupina SQL Server ) číst kód, aby lépe porozuměl logice produktu ve všech situacích, které nejsou zřejmé. Kromě toho společnost Microsoft využila příležitosti sestavit malý tým vývojářů pro studium zdrojového kódu pro SQL Server. Tato skupina provedla kontrolu kódu řádek po řádku v těch částech programu, kde existovalo podezření na chybu, a provedla „virtuální opravy chyb“ (protože stále neměli možnost provádět změny v SQL kód serveru). Když se však takové zprávy s analýzou zdrojového kódu začaly odesílat do Sybase, opravy kritických chyb pro Microsoft začaly docházet mnohem rychleji. Po několika měsících v tomto režimu provozu, v polovině roku 1991, Microsoft konečně dostal příležitost opravit chyby přímo v kódu. Ale protože Sybase stále kontrolovala zdrojový kód produktu, veškeré změny kódu byly předem zaslány Sybase ke kontrole. Vývojáři Microsoftu se tak stali odborníky na kód SQL Serveru, což umožnilo na jedné straně zlepšit jeho podporu a na druhé straně věnovat větší pozornost jeho kvalitě.
V roce 1991 společnost Microsoft vydala prozatímní verzi SQL Server 1.11. Toto vydání bylo způsobeno skutečností, že seznam uživatelů se v té době již výrazně rozšířil. Přestože architektura klient-server stále nebyla příliš rozšířená, zákazníci na ni stále postupně přecházeli. Navzdory pozitivní kritice ze strany odborného tisku však prodej SQL Serveru stále ještě nebyl splněn. Hodně z toho bylo kvůli selhání OS/2. Namísto očekávaného přechodu z MS-DOS na OS/2 preferovali domácí uživatelé PC přechod na Windows 3.0. V důsledku toho byly prodeje Windows 3.0 poměrně silné. Aby urychlil prodej SQL Server a LAN Manager, Microsoft oznámil speciální program na podporu nezávislých dodavatelů softwaru, v jehož rámci si každý vývojář splňující určité požadavky mohl licencovat oříznuté verze těchto produktů (tyto verze umožňovaly pouze software třetích stran, tzv. -tzv . anglické. run-time verze ) se 40% slevou a zároveň získat půl roku podpory zdarma a také některé další výhody [9] .
Jak informoval časopis InfoWorld koncem července 1991, oznámení společnosti Microsoft o nové verzi SQL Server se zaměřilo na vylepšené sítě a novou aplikaci Windows pro správu databází. Microsoft konkrétně slíbil, že do jednoho roku poskytne kopii SQL Commander registrovaným uživatelům SQL Server pro OS/2. Nástroj nazvaný SQL Commander byl představen dříve v květnu 1990 společností Datura Corp. (dříve známá jako Strategic Technologies Group). Tento nástroj usnadnil správcům databází správu uživatelských účtů, indexů tabulek, spouštěčů a složitých dotazů. Jak však kritici poznamenali, funkce tohoto nástroje se téměř zcela shodovaly s jiným nástrojem od společnosti Microsoft - nástrojem Server Administration Facility, který byl dodán se serverem SQL Server. SQL Server 1.11 navíc přidal podporu pro nástroje pro správu sítě Novell, tehdy nový nástroj OS/2 Requester 1.3 a podrobnou technickou dokumentaci pro uživatele Novell. Síťová vylepšení zahrnovala vylepšené sítě Novell , přidanou podporu pro protokoly Banyan VINES 4.10 a interakci klienta se Sybase SQL Server na strojích UNIX nebo VMS . Změnila se také licenční politika: verze pro 5 uživatelů byla nahrazena verzí pro 10 uživatelů a uživatelé SQL Serveru 1.1 s neomezeným počtem uživatelů mohli získat verzi 1.11 zdarma [10] .
Ale na druhou stranu měl SQL Server 1.11 velmi hmatatelná omezení, včetně škálovatelnosti. Byl to 16bitový produkt, protože OS/2 podporoval pouze 16bitový adresní prostor pro aplikace a jeho výkon byl omezen nedostatkem výkonových mechanismů OS/2, jako je asynchronní I/O. Navzdory skutečnosti, že SQL Server na OS / 2 v té době dokázal zvládnout většinu úkolů, existoval určitý limit, po kterém se server prostě začal „dusit“. Neexistovala žádná dobře definovaná hranice, ale SQL Server na OS/2 byl použit pro pracovní skupiny až 50 lidí. Pro větší skupiny byla k dispozici verze Sybase SQL Server pro vysoce výkonné systémy založené na UNIX nebo VMS . A právě zde procházela prodejní linka mezi Microsoftem a Sybase. Zákazníci, kteří si vybírají produkt od Microsoftu, chtěli mít jistotu, že jej jejich požadavky „nepřerostou“. Velké množství softwarových nástrojů vyvinutých pro Microsoft SQL Server fungovalo bez větších úprav se Sybase SQL Serverem a aplikace, které již nemohly být uspokojeny OS / 2, mohly být snadno přeneseny na výkonnější systém UNIX. Tento vztah byl výhodný pro obě společnosti, protože velké množství softwarových nástrojů pro Microsoft SQL Server obvykle fungovalo bez problémů se Sybase SQL Serverem a aplikace, které již neměly dostatečný výkon OS/2, snadno fungovaly se servery UNIX.
Mezitím se konkurence na trhu DBMS postupně zvyšovala, stejně jako požadavky zákazníků na software, který si vybírají, v důsledku vývoje další verze SQL Serveru pro Microsoft, problémů s kompatibilitou a interoperabilitou, jakož i potřeby do popředí se dostaly implementace nové funkcionality za účelem uspokojení požadavků zákazníků. Vzhledem k tomu, že nová verze produktu byla potřeba co nejrychleji, začal Microsoft vyvíjet další verzi krátce po vydání SQL Server 1.11.
Objevil se však dotaz na další číslo nové verze. Faktem je, že souběžně s prodejem Microsoft SQL Server 1.0 probíhal i prodej Sybase SQL Server 3.0, který přinesl na trh DBMS pro PC některé velmi používané mechanismy, jako jsou textové a obrazové datové typy a také režim procházení dat ( anglicky browse mode ). A další verzí Sybase SQL Server byla verze 4.0 pro nejběžnější platformy a verze 4.2 pro ty méně obvyklé. Vývoj nové verze Microsoft SQL Server byl tedy ve skutečnosti založen na zdrojovém kódu Sybase SQL Server 4.2. V souladu s tím byla pro marketingové účely nová verze Microsoft SQL Server také označena číslem 4.2.
Již v květnu 1991 však Microsoft a IBM oznámily, že zastavují společný vývoj OS/2, protože v té době již bylo zřejmé, že uživatelé preferují Windows před OS/2. Microsoft se tak rozhodl zaměřit na další vývoj Windows a také softwaru pro ně. V té době již Microsoft vyvíjel novou verzi operačního systému založenou na mikrokernelu s kódovým označením NT (zkráceně z anglického new technology - „new technology“). Původně se mělo jednat o novou verzi OS/2 (někdy dokonce označovanou jako OS/2 3.0). Po ukončení kolaborativního vývoje bylo rozhodnuto přeorientovat projekt na Windows, tedy přidat uživatelské rozhraní ve stylu Windows a Win32 API , v důsledku čehož dostal projekt nový název - Microsoft Windows NT .
Podle tehdejších plánů měla být první verze Windows NT vydána nejdříve o 2 roky později a Microsoft SQL Server měl být nakonec portován na Windows NT, což se nezdálo jako nejchytřejší krok. S tím vším však musel Microsoft podporovat vývoj SQL Serveru pro OS/2, přestože OS/2 byl nyní v podstatě konkurenčním produktem pro samotný Microsoft. Na druhou stranu Microsoft do toho šel, protože v té době neměl žádnou alternativu.
Microsoft vyvinul SQL Server 4.2 pro nadcházející OS/2 2.0, první 32bitovou verzi OS/2. Vzhledem k tomu, že SQL Server 4.2 měl být 32bitový, zdálo se jednodušší jej přenést z řady UNIX, protože v tomto případě nebyl problém se segmentací paměti naléhavý. Teoreticky by měl být 32bitový SQL Server také produktivnější. V tisku se objevilo mnoho článků věnovaných srovnávání výkonu na 16bitových a 32bitových platformách a téměř všichni autoři si byli jisti, že přechod na 32bitovou platformu přinese výrazné zvýšení výkonu (ačkoli některé články objasňují, za jakých podmínek by to být (nebo ne) přesně takový). Adresování paměti bylo považováno za hlavní zdroj zvýšení výkonu. K jeho provedení v 16bitovém segmentovaném adresním prostoru řady OS/2 1.x byly zapotřebí alespoň 2 instrukce: první instrukce načetla požadovaný segment paměti, druhá načetla požadovanou adresu v tomto segmentu. Při 32bitovém adresování nebyla potřeba instrukce pro načtení segmentu, a tak mohla být paměť adresována pouze jednou instrukcí. Podle některých propočtů by díky tomu mohlo být potenciální celkové zvýšení produktivity až o 20 %.
V té době se mnoho lidí mylně domnívalo, že SQL Server musí běžet na plnohodnotné 32bitové platformě, aby mohl adresovat více než 16 MB paměti. Při spuštění na OS/2 1.x měla aplikace přístup pouze k 16 MB skutečné paměti. A přestože se naskytla možnost získat více než 16 MB virtuální paměti, pak stránkování začalo mít svůj negativní dopad . V OS/2 2.0 by aplikace mohla adresovat více než 16 MB paměti a přesto se vyhnout jejímu odkládání. To zase umožnilo SQL Serveru mít velkou mezipaměť a získat všechna potřebná data z paměti rychleji než z disku, což mělo velmi pozitivní vliv na zvýšení výkonu. Z pohledu aplikace však byla veškerá paměť v OS/2 virtuální (jak 1.x, tak 2.x), takže i 16bitová verze SQL Server mohla využít OS/2 2.0 k přístupu k většímu skutečnému paměťovému prostoru. . Z tohoto pohledu 32bitová verze prostě nebyla potřeba.
Ukázalo se však, že rané beta verze OS/2 2.0 byly výrazně pomalejší než OS/2 1.x, čímž byly popřeny všechny výhody nového přístupu k adresování paměti. V důsledku toho uživatelé místo očekávaného zvýšení výkonu zaznamenali vážný pokles výkonu při spouštění prvních sestavení 32bitového serveru SQL Server 4.2 na OS/2 2.0 (ve srovnání s SQL Server 1.1).
Neočekávaně byly plány na vydání OS/2 2.0 do konce roku 1991 revidovány. Ve skutečnosti se stalo nejasným, zda se IBM vůbec bude podílet na vydání verze 2.0. To znamená, že vydání OS / 2 2.0 před koncem roku 1992 nemuselo čekat. S ohledem na tuto situaci byl Microsoft nucen vrátit se k 16bitové implementaci SQL Serveru a přesměrovat jej na OS/2 1.3. Vývojářům Microsoftu trvalo asi tři měsíce, než se vrátili k 16bitové implementaci, ale pak se objevil další problém: verze OS / 2 1.3 dodávaná IBM fungovala pouze na jejích licencovaných počítačích. Teoreticky by výrobci počítačů třetích stran mohli licencovat OS/2 od společnosti Microsoft a dodávat jej jako součást smlouvy OEM . Poptávka po OS/2 však klesla natolik, že se většina výrobců OEM rozhodla do toho nezasahovat, takže nákup OS/2 pro počítače třetích stran je obtížný. Společnost Microsoft jako řešení vytvořila oříznutou verzi OS/2 verze 1.3 (kódové označení Tiger), která byla dodána ve stejné krabici jako Microsoft SQL Server a Microsoft LAN Manager. Zároveň se stále více stávalo zřejmé, že OS / 2 je již „mrtvým“ OS.
Beta testování Microsoft SQL Server 4.2 začalo na podzim roku 1991 a v lednu 1992 na konferenci v San Franciscu pro vývojáře softwaru používající Microsoft SQL Server, Bill Gates , tehdejší generální ředitel společnosti Microsoft, a Bob Epstein, zakladatel a vůdce Sybase, oficiálně oznámil produkt. Verze 4.2 byla první skutečně kolaborativní verzí. Databázový stroj byl portován ze zdrojového kódu UNIX verze 4.2, přičemž inženýři společností Microsoft a Sybase spolupracovali na portování a opravě chyb. A co víc, Microsoft vytvořil knihovny klientského rozhraní pro MS-DOS, Windows a OS/2 a poprvé zahrnul nástroj Windows GUI pro zjednodušení správy. Zdrojový kód byl konsolidován v ústředí Sybase a soubory zdrojového kódu tam byly odesílány prostřednictvím vytáčeného připojení nebo kopírováním a zasíláním magnetických pásek poštou.
Microsoft SQL Server 4.2 se začal dodávat v březnu 1992. Kritika v odborném tisku byla poměrně příznivá, stejně jako recenze zákazníků na produkt. Po zahájení dodávky v roce 1992 se však mnozí zajímali o načasování vydání 32bitové verze SQL Server. Jak ukázaly následné události, tato verze enginu byla poslední verzí, kterou Microsoft obdržel od Sybase (kromě několika oprav chyb, které si společnosti nějakou dobu vyměňovaly).
Začátkem roku 1992 byl vývojový tým SQL Serveru na křižovatce. Na jedné straně již existovala klientská základna SQL Server, jehož DBMS byl nainstalován na OS / 2. Tito zákazníci se již těšili na 32bitovou verzi SQL Server a verzi pro OS/2 2.0 a nejlépe ihned po vydání OS/2 2.0 od IBM, což znamená, že chtěli zůstat na OS/2 pro blízká budoucnost. Problém byl ale v tom, že se přesně nevědělo, kdy OS/2 2.0 vyjde. Zástupci IBM uvedli, že vydání nové verze proběhne na podzim roku 1992. Mnozí tato slova vnímali skepticky. Například Steve Ballmer , senior viceprezident Microsoftu, veřejně přísahal, že sní disketu , pokud IBM vydá jejich produkt v roce 1992.
Na druhou stranu byli vývojáři SQL Serveru povinni přenést svůj produkt na Windows NT co nejdříve a nejlépe tak, aby beta verze obou produktů byly vydány přibližně ve stejnou dobu. Windows NT byl v té době považován za produkt Microsoftu vyšší cenové kategorie a z pohledu vývojářů měl tento OS oproti OS/2 také několik technických výhod: asynchronní I/O, symetrické multithreading, přenositelnost na RISC architektura.
Kromě toho, přestože se Microsoft v roce 1991 rozhodl vrátit k 16bitové verzi SQL Serveru, práce na 32bitové verzi se nezastavily. V březnu 1992, kdy byla poprvé vydána verze 4.2, testy ukázaly, že obě verze (16bitová i 32bitová) na beta verzích OS/2 2.0 byly pomalejší než 16bitová verze běžící na OS/2 1.3. Možná by se po oficiálním vydání OS / 2 2.0 situace změnila, ale v té době dostupné beta verze naznačovaly spíše opak. Ve skutečnosti se ukázalo, že práce je méně produktivní a méně stabilní.
Vzhledem k tomu, že zdroje na vývoj byly omezené, Microsoft si v současné situaci nemohl dovolit vyvíjet pro obě platformy najednou. V opačném případě by vývojáři čelili další hromadě problémů, konkrétně by museli do produktu přidat abstraktní vrstvu, která by skryla rozdíly mezi operačními systémy, nebo by paralelně vyvíjeli dvě verze produktu. Vývojáři z Microsoftu se tedy rozhodli přestat pracovat na 32bitové verzi SQL Serveru pro OS/2 2.0 a místo toho se rovnou vrhnout na vývoj produktu pro Windows NT. Při vývoji nové verze přenositelnosti SQL Serveru na OS/2 nebo jiných operačních systémech tomu nebyla věnována pozornost, místo toho bylo rozhodnuto plně využít výhod Windows NT. V souladu s tím tento přístup účinně ukončil vývoj SQL Serveru pro OS / 2 obecně, s výjimkou podpory již vydaných verzí a oprav v nich. Microsoft začal své zákazníky informovat, že vzhled budoucích verzí (včetně 32bitové verze) SQL Serveru pro OS/2 2.0 bude záviset na dostupnosti a objemu poptávky zákazníků, přičemž sám přesunul své zaměření na Windows NT. Vnímání takových novinek zákazníky bylo různé: někteří na takovou pozici reagovali s pochopením, jiní, jejichž podnikání přímo záviselo na OS / 2, se takové novinky nelíbily.
Mezitím Sybase také pracoval na nové verzi své databáze, která se měla jmenovat System 10. V této situaci, stejně jako v případě vývoje verze 4.2, vývojáři potřebovali, aby nová verze Microsoft SQL Server byla kompatibilní se systémem 10 a mají stejné sériové číslo jako produkt Sybase vydaný pro UNIX. Nastala tedy situace, kdy hlavním cílem pro Microsoft bylo vítězství Windows NT nad OS / 2 a pro Sybase - úspěch jeho System 10.
I když System 10 ještě ani nevstoupil do beta fáze, v plánech obou společností na vydání nových verzí produktu již existovaly nesrovnalosti. Microsoft například chtěl co nejdříve portovat Microsoft SQL Server na Windows NT a také získat verzi System 10 pro Windows NT, OS/2 2.0 nebo oba. V důsledku toho bylo dosaženo dohody, že Microsoft přenese SQL Server 4.2 pro OS/2 na Windows NT a začne okamžitě a Sybase zařadí Windows NT do seznamu prioritních OS pro systém 10. Windows NT tak budou jeden z prvních OS, pro který bude vydána odpovídající verze System 10. Na oplátku Microsoft obnoví podporu OS/2 pro Sybase, takže zákazníci, kteří si přejí zůstat na OS/2, tak mohou dobře učinit. Microsoft sice doufal, že většina zákazníků přejde na Windows NT, ale bylo jasné, že se to stoprocentně nestane. Proto byla v tomto ohledu taková dohoda pro Microsoft dokonce výhodná.
Kromě toho měl takový akční plán další výhody z hlediska rozvoje. Vývojový tým Microsoftu měl pracovat na stabilní a otestované verzi 4.2, které v té době již dokonale rozuměli, což značně usnadnilo jeho portování na nový OS. Sybase se zase mohl plně soustředit na vývoj nové verze, aniž by se staral o problémy spojené s předběžnými verzemi operačního systému. V důsledku toho měly být podle tehdejšího plánu (1992) vydány obě verze (System 10 a SQL Server pro Windows NT) a společnosti měly pokračovat ve vývoji produktu společně.
Tým SQL Server ve společnosti Microsoft zahájil rychlý vývoj první verze SQL Server pro Windows NT, protože tým musel vydat produkt do 90 dnů od Windows NT, ale plán byl dodržet termín 30 dnů. Zde se počítalo s tím, že Windows NT byl nyní fakticky jedinou platformou pro SQL Server, což znamenalo, že se vývojáři nemuseli starat o problémy s portováním, a zejména nemuseli vyvíjet abstraktní vrstvu, která by skryla rozdíly mezi operačními systémy. Roli abstraktní vrstvy měl sehrát samotný Windows NT, který byl původně plánován jako přenosný OS, tedy měl vydávat své verze pro různé strojové architektury.
Výsledkem je, že vývojáři těsně spojili funkčnost SQL Serveru s funkčností Windows NT, jako je zpracování událostí na jednom místě, instalace SQL Serveru jako služby Windows NT, export statistik výkonu DBMS do Windows NT Performance Monitor atd. Od Windows NT poskytl aplikacím možnost spouštět dynamický kód (pomocí dynamických knihoven), pak SQL Server poskytl možnost vývojářům třetích stran vytvářet své vlastní dynamické knihovny. V důsledku těchto změn se Microsoft SQL Server pro Windows NT velmi lišil od původní verze 4.2 pro OS / 2, protože se ukázalo, že Microsoft skutečně přepsal jádro SQL Server (část programu zodpovědná za interakci s OS ) pracovat přímo s Win32 API.
Dalším cílem při vývoji SQL Serveru pro Windows NT bylo usnadnit přechod ze stávajících instalací na OS/2 na novou verzi SQL Server a OS. Vývojáři chtěli, aby všechny aplikace napsané pro SQL Server 4.2 pro OS/2 běžely beze změny na SQL Serveru pro Windows NT. Protože Windows NT měl být schopen duálního spouštění s MS-DOS nebo OS/2, tým se rozhodl, že SQL Server pro Windows NT by měl být schopen přímo číst a zapisovat do databází vytvořených v SQL Server pro OS/2. K dosažení těchto cílů vývojáři přepracovali vnitřní architekturu SQL Serveru, přidali mnoho funkcí pro správu, síťování a rozšiřitelnost, zatímco přidání externích funkcí do jádra enginu muselo být opuštěno. Další obavou byla kompatibilita dialektů SQL a vlastností verzí DBMS pro Windows NT a OS/2, přičemž nové funkce měly být přidány do verze, která bude vyvíjena na základě System 10. Rozlišovat kompatibilitu s verze 4.2 pro OS/2 a nový vývoj Sybase se Microsoft rozhodl pojmenovat svou novou verzi SQL Server pro Windows NT 4.2 (tj. přidáním čísla verze) s marketingovým názvem produktu Microsoft SQL Server pro Windows NT, a interní označení je SQL NT.
V červenci 1992 uspořádal Microsoft konferenci pro vývojáře softwaru pro platformu Windows NT a účastníkům konference distribuoval alfa verze Windows NT. Navzdory skutečnosti, že nová verze SQL Server neměla ani status „beta verze“, Microsoft přesto okamžitě vydal prostřednictvím CompuServe 32bitové softwarové knihovny, které vývojáři potřebují k portování svých aplikací z OS/2 a 16bitových verze Windows až Windows NT. To bylo provedeno s ohledem na úspěch distribuce NDK mezi vývojáře softwaru pro Windows 3.0 v roce 1990, ale Microsoft doufal, že tento úspěch zopakuje tím, že poskytne vývojářům všechny potřebné nástroje pro vývoj softwaru pro Windows NT.
V říjnu 1992 společnost Microsoft vydala první beta verzi SQL Server pro Windows NT. Tato verze měla všechny hlavní (z deklarované) funkčnosti a všechny její součásti měly plnou podporu pro Win32. Tato verze byla distribuována za pomoci více než stovky webů. Pro DBMS byl tento počet míst bezprecedentní, protože typický počet míst přidělených pro distribuci tohoto typu softwaru zpravidla nepřesahoval 10.
Souběžně s distribucí NDK stále probíhaly dodávky verze OS/2 SQL Serveru (pokračovaly i v následujícím roce). V březnu 1993 společnost Microsoft vydala beta verzi produktu. Tato verze (SQL Server Client/Server Development Kit (CSDK)) byla volně k dispozici ke koupi za malý poplatek. Na jeho podporu uspořádal MIcrosoft otevřené fórum na CompuServe a nepožadoval, aby ti, kdo jej kontaktovali, podepsali smlouvu o mlčenlivosti. Podařilo se tak realizovat více než tři tisíce stavebnic CSDK. V květnu 1993 převyšovala podpora předběžného produktu podporu verze OS/2. Navzdory množství příspěvků byl celkový ohlas na produkt před vydáním vcelku pozitivní.
V červenci 1993 vydala společnost Microsoft Windows NT 3.1. Do 30 dnů od vydání vydal vývojový tým SQL Server první verzi Microsoft SQL Server pro Windows NT. Výstup byl velmi úspěšný: rostly prodeje jak samotného DBMS, tak operačního systému pro něj.
Začátkem prosince 1993 přešlo značné množství zákazníků z OS/2 na SQL Server pro Windows NT. Průzkumy ukázaly, že ti, kteří ještě nemigrovali na novou verzi pro Windows NT, tak plánují udělat, a to navzdory oznámení Sybase o svém záměru vyvinout System 10 pro OS/2. Migrace z SQL Server pro OS/2 na Windows NT pro aplikace byla poměrně bezbolestná a došlo také ke zvýšení výkonu. Výsledkem je, že po 9 měsících byly prodeje SQL Serveru již dvakrát vyšší než prodeje na začátku tohoto období. Přitom 90 % prodejů pocházelo z nové verze pro Windows NT, zatímco stará verze pro OS/2 tvořila zbývajících 10 %.
Interní testy Microsoftu ukázaly, že zaměření na jedinou platformu (Windows NT) se vyplatilo: SQL Server pro Windows NT (běžící na levnějším hardwaru) překonal DBMS běžící na UNIXu a dražším hardwaru. V září 1993 Compaq Computer Corporation zveřejnila první výsledky testu Transaction Processing Council (TPC). V té době byl podle testů TPC-B nejběžnějším ukazatelem 1000 $/TPS ( transakce za sekundu , transakce za sekundu). SQL Server běžící na stroji se dvěma 66MHz procesory Pentium dodal 226 TPS za 440 USD za transakci, což je poloviční cena oproti dříve publikovaným benchmarkům. Současně většina souborových serverů běžících na minipočítačích UNIX vykazovala výsledky, které nepřesahovaly 100 TPS. A přestože existovaly některé DBMS, které vykazovaly výrazně vyšší sazby, jejich cenový ekvivalent byl výrazně vyšší než 440 USD/TPS. Pro srovnání, o 18 měsíců dříve byl výkon 226 TPS nejvyšší, jaké kdy sálový počítač nebo mini PC dosáhl.
Úspěch Microsoftu způsobil nárůst napětí se Sybase. Situace na trhu DBMS na konci roku 1993 byla již velmi odlišná od situace v roce 1987, kdy Microsoft a Sybase podepsaly smlouvu. V roce 1993 byla Sybase již úspěšnou softwarovou společností, na trhu DBMS na druhém místě za Oracle Corporation . Stejně tak Microsoft od roku 1987 výrazně vzrostl. Spolu s tím se rozrostl i vývojový tým SQL Serveru (v roce 1990 to byl asi tucet lidí a v roce 1993 více než 50), nepočítaje ty, kteří se podíleli na marketingu a podpoře produktu. Tito vývojáři již dobře znali vnitřnosti SQL Serveru a měli také bohaté zkušenosti s vývojem podobné verze pro Windows NT. Microsoft tedy již měl všechny potřebné zdroje k nezávislému vývoji SQL Serveru, ale smlouva se Sybase z roku 1987 ho zavazovala, protože smlouva znamenala pouze to, že licencoval vývoj od Sybase. Podle podmínek této smlouvy společnost Microsoft nemohla přidávat nové funkce ani provádět žádné jiné změny kódu bez předchozího souhlasu společnosti Sybase.
Dalším důvodem vzájemné nespokojenosti byla konečná odlišnost potřeb při vývoji SQL Serveru. Například vývojáři Microsoftu chtěli integrovat podporu MAPI (Messaging API) do SQL Serveru, ale protože tato funkce byla specifická pro Windows, vývojáři Sybase nijak nespěchali, aby dali zelenou její implementaci, protože Sybase měla zájem vyvinout produkt. pro UNIX a ne pro Windows NT. Protože Sybase nezískala žádnou výhodu z portování svého produktu na jiné operační systémy, iniciativy Microsoftu začaly narážet na rostoucí odpor. Portování verze 4.2 na Windows NT již ve skutečnosti bylo předmětem sporu, protože přidání funkcí specifických pro Windows NT ve verzi 4.2 výrazně brzdilo vývoj systému 10 pro jiné platformy. Sybase vyvíjel svůj System 10 s ohledem na zjednodušení dalšího portování na různé operační systémy (včetně Windows NT), ale z pohledu Microsoftu to znamenalo opustit maximální možné využití nástrojů Windows NT, protože System 10 nemohl a chtěl by neschopnost takového přístupu k práci na Windows NT je tak efektivní, jako kdyby byl pro ně původně vyvinut.
To vše vedlo k tomu, že se nyní obě společnosti navzájem skutečně nepotřebovaly a jejich dohoda z roku 1987 vlastně přestala fungovat. Microsoft SQL Server pro Windows NT již byl životaschopnou alternativou k Sybase SQL Server běžícímu na UNIX, Novell NetWare a VMS. Zákazníci si nyní mohli zakoupit Microsoft SQL Server za zlomek ceny podobného řešení UNIX, přičemž MS SQL Server běží na méně výkonném (a tedy levnějším) hardwaru a vyžaduje méně kvalifikovanou osobu, aby jej spravovala. Na druhou stranu licenční poplatky od Microsoftu by byly jen malým zlomkem příjmů Sybase z prodeje jejích UNIXových produktů. Obě společnosti tedy již bojovaly o prakticky stejné zákazníky, ale zároveň už obě pochopily, že je čas změnit povahu jejich vztahu.
12. dubna 1994 Microsoft a Sybase oznámily konec společného vývoje SQL Serveru. Každá společnost se rozhodla pokračovat v práci na své vlastní verzi SQL Serveru. Microsoft dostal příležitost vyvíjet Microsoft SQL Server nezávisle, aniž by se ohlížel na Sybase. Sybase nyní mohla volně přenášet systém 10 na Windows NT (poprvé byl SQL Server s logem Sybase dostupný na platformě Windows NT, protože jejich dohoda znamenala pouze vývojová práva společnosti Microsoft pro tuto platformu). Oba produkty si přitom měly zachovat zpětnou kompatibilitu se stávajícími aplikacemi pro SQL Server v té době, ale do budoucna tato myšlenka nebyla kvůli příliš odlišným cílům nijak podporována. Sybase navrhl svůj produkt především pro kompatibilitu s verzemi UNIX, zatímco Microsoft se zaměřil na kompatibilitu s Windows NT. Brzy si obě řady SQL Serveru začaly přímo konkurovat a Microsoft se opět dostal do dvojí situace: musel podporovat konkurenční produkt (System 10) na platformě Windows NT, protože dostupnost různých produktů měla pozitivní vliv na prodej OS.
Počátkem roku 1994 plánoval vývojový tým SQL Serveru převzít zdrojový kód Sybase System 10 pro novou verzi, ale přerušení dohody tyto plány zcela změnilo. Kromě několika oprav byly poslední zdroje od Sybase přijaty počátkem roku 1992 (verze 4.2 pro OS/2). Vzhledem k tomu, že se Sybase chystala vydat System 10 pro Windows NT do konce tohoto roku, byl by to pro uživatele dobrý důvod upgradovat svou verzi DBMS z Microsoft SQL Server 4.2 na Sybase System 10. to znamenalo ztrátu zákaznické základny, a proto bylo nutné rychle připravit odpověď.
Microsoft rychle naplánoval ambiciózní verzi obsahující mnoho vylepšení výkonu a funkčnosti. Nadcházející verze byla označena kódovým označením SQL95, což naznačuje plánované vydání Windows 95 . V roce 1994 byla otázka replikace dat pomocí DBMS aktuální, takže replikace se stala základním kamenem budoucího vydání. Totéž platilo o polohových kurzorech , což je mechanismus podle vývojářů prostě nezbytný k překlenutí mezery mezi aplikacemi zaměřenými na práci s mnoha záznamy a relační databází. Žádný z populárních DBMS v té době ještě neměl plnohodnotnou implementaci polohových kurzorů pro architekturu klient-server a vývojový tým SQL Serveru věřil, že tento mechanismus pozitivně ovlivní reputaci jejich produktu. Kromě toho probíhaly práce na zcela nové sadě nástrojů pro správu s kódovým označením Starfighter (později nazvané SQL Server Enterprise Manager), která měla být zahrnuta do příští verze. Seznam novinek se postupně stále více rozšiřoval.
Obecné reakce zákazníků na zprávy o plánech Microsoftu na vývoj samotného SQL Serveru byly spíše negativní. 14. června 1994 uspořádal Microsoft v San Franciscu generální konferenci pro zákazníky, analytiky a novináře. Jim Allchin, tehdejší senior viceprezident společnosti Microsoft, hovořil o budoucích plánech a plánovaném vydání SQL95. Prezentované plány a návrhy byly přijaty se souhlasem, ale mnozí otevřeně vyjádřili skepsi ohledně data vydání a pochybovali, že Microsoft bude schopen vydat slibovaný produkt do konce roku 1995. Tisk dokonce sarkasticky označoval nové vydání jako SQL97 a dokonce SQL2000. Podle interních plánů se vývojáři připravovali na představení vydání v první polovině roku 1995. První beta verze byla vydána v říjnu 1994. V tomto okamžiku Starfighter ještě nebyl dokončen, ale samotný server již byl dokončen, a protože právě při stahování serveru vytváří největší zátěž na stránkách s beta verzemi, bylo rozhodnuto vydat nejprve jeho beta verzi. Po vydání následovala řada aktualizací trvající několik měsíců, souběžně s nárůstem počtu stránek, které dosáhly čísla 2000 stránek.
V roce 1993 se navíc Microsoft rozhodl, že databáze budou klíčovou technologií v jeho kompletní produktové řadě, a koncem roku 1994 začal Microsoft zadávat odborné poradenství od DEC a dalších klíčových tržních prodejců pro vývojové týmy pracující na Microsoft Jet a SQL. Server. Účelem této konzultace bylo naplánovat komponenty pro novou generaci databázových produktů. Během roku 1995, souběžně s vydáním SQL Serveru 6.0 a SQL Serveru 6.5 hlavního týmu, druhý tým vyvinul nový dotazovací procesor jako součást toho, co se stalo Microsoft Data Engine (MSDE). Souběžně s vývojem MSDE probíhaly práce na OLE DB , sadě rozhraní, která by umožnila vyvíjet prvky základního produktu SQL Server jako nezávislé komponenty. Takové komponenty by byly schopny mezi sebou komunikovat pomocí vrstvy OLE DB.
Zhruba devět měsíců probíhaly práce na SQL Serveru také v noci. 14. června 1995 byl produkt vydán pod názvem Microsoft SQL Server 6.0, čímž byly splněny podnikové termíny. Po vydání verze následovala řada pozitivních publikací v odborném tisku. Časopis InfoWorld ve svém druhém výročním průzkumu mezi 100 společnostmi s nejinovativnějšími klient/server aplikacemi zařadil Microsoft SQL Server jako druhý největší systém pro správu databází. Zároveň SQL Server zvýšil svůj podíl z 15 % na 18 % mezi respondenty, kteří uvedli tento DBMS jako svou volbu, zatímco podíl Oracle DBMS se snížil z 24 % na 19 %. Podíl Sybase také vzrostl z 12 % na 14 %. Tři z deseti nejlepších aplikací InfoWorldu byly vytvořeny pomocí Microsoft SQL Server.
Byly však důkazy, že tržní podíl Microsoft SQL Server je mnohem menší, než ukázaly podobné průzkumy. Jedním z problémů bylo, že Microsoft byl v sektoru DBMS stále nováčkem. V té době byl jasným lídrem Oracle a vážné pozice měly Sybase, Informix a IBM. Trh je ve skutečnosti pro Microsoft velmi znepokojující situace, protože všechny tyto společnosti začaly budovat svou prodejní taktiku proti Microsoft SQL Server. Sybase, Informix a Oracle zároveň plánovaly vydat nové verze svých produktů. V rámci strategie vývoje SQL Serveru Microsoft nadále aktivně posiloval vývojový tým SQL Serveru, který měl v té době již více než čtyřletou historii. Byli přijati jak v té době již známí profesionálové, jako Jim Gray , Dave Lomet a Phil Bernstein tak i méně známí vývojáři včetně bývalých zaměstnanců DEC, kteří na Rdb pracovali .
Po vydání verze 6.0 byly zahájeny práce na verzi 6.5. V rámci nové verze bylo plánováno implementovat ty funkce, které byly odloženy při vydání verze 6.0, zejména proto, že za 18 měsíců jejího vývoje požadavky na DBMS výrazně vzrostly. Například v roce 1995 již hrál velkou roli internet a přenos dat. Vydání verze 6.5 mělo tyto požadavky uspokojit. Plně funkční beta verze verze 6.5 byla vydána 15. prosince 1995 prostřednictvím 150 beta stránek. Oficiální dodávky nové verze začaly v dubnu 1996, tedy přibližně 10 měsíců po vydání verze 6.0.
K funkcionalitě byly také přidány nástroje pro zjednodušení používání produktu uživateli, rozšířená podpora pro distribuované transakce a další funkce. Získal také certifikát o shodě s jazykovým standardem ANSI SQL.
Později, v prosinci 1997, souběžně s vydáním druhé beta verze SQL Server 7.0, byl vydán také SQL Server 6.5 EE, který měl podporu pro dvouuzlové clustery převzetí služeb při selhání Microsoft Cluster Server, 8 procesorů a 3 GB adresního prostoru.
Koncem roku 1995 začal vývoj další verze SQL Server s kódovým označením Sphinx . Již v první fázi byl budoucí kód MSDE přidán do kódu SQL Serveru a vývojový tým, který na něm pracoval, se připojil k základnímu vývojovému týmu SQL Serveru. Vývoj nové generace SQL Serveru měl jeden hlavní cíl: přepracovat celý engine databázového serveru tak, aby uživatelům umožňoval škálovat SQL Server podle jejich přání. To znamenalo postupné navyšování kapacity pro maximální využití rychlejších procesorů (a také zvyšování jejich počtu) a množství paměti dostupné operačnímu systému. Kromě toho by takové rozšíření nemělo omezovat možnost přidávat nové funkce do žádné z komponent, například nový algoritmus pro připojení nového pevného disku by mohl být snadno přidán do kódu obsluhy požadavků. Kromě tohoto škálování musel SQL Server podporovat nové třídy databázových aplikací, což zase znamenalo opak škálování, konkrétně snížení hardwarových požadavků tak, aby produkt mohl fungovat na mnohem slabších systémech, jako je domácí PC nebo notebooky.
V krátkodobém horizontu bylo díky takovému přepracování plánováno dosáhnout dvou cílů:
Jednou z oblastí, které se během vývoje věnovala velká pozornost, bylo zlepšování výkonu aplikací na vysoké úrovni, jako je software pro plánování podnikových zdrojů. Zde byla vyžadována škálovatelnost a snadné použití spolu s vysokou spolehlivostí databázového stroje. Bylo také vyvinuto několik algoritmů, které automatizují většinu konfigurace databáze a umožňují systému zvládnout některé problémy s konfigurací, kterým správce databáze čelí. Podle těchto algoritmů Microsoft následně obdržel několik patentů. Pracovalo se také na zajištění uzamykacího mechanismu na rekordní úrovni. Tento mechanismus by aplikacím umožnil přístup ke konkrétnímu řádku v tabulce spíše než k celé stránce, což by výrazně snížilo počet konfliktů, pokud by došlo k více současným změnám dat ve stejné tabulce. Ve verzi 6.5 měl tento mechanismus velmi omezenou implementaci, takže nová verze již předpokládala implementaci plného zamykání na rekordní úrovni [11] .
V říjnu 1996 Microsoft získal technologii Plato od izraelské společnosti Panorama Software Systems. Tato technologie byla jednou z implementací technologií OLAP pro DBMS. V té době (stejně jako v době vydání SQL Server 7.0 v roce 1998) byla technologie OLAP považována za velmi obtížně použitelnou, a proto byla málo využívána. Bylo však učiněno rozhodnutí zabudovat Plato do kódu SQL Server 7.0, ale vzhledem k požadavkům na škálování nové verze SQL Serveru bylo výsledkem, že Plato musel být přepracován, aby splňoval podobné požadavky. Vývojáři měli za úkol z něj udělat produkt, který se z hlediska škálovatelnosti, snadného použití a integrace se softwarem korporace nebude lišit od žádného produktu Microsoftu. V budoucnu se OLAP server, který se stal jedním z klíčových přírůstků k SQL Server 7.0, jmenoval OLAP Services [11] .
V prosinci 1996 byl vydán Microsoft Transaction Server 1.0 (kódové označení Viper), který kombinuje funkce transakčního monitoru a zprostředkovatele objektových požadavků.
V červnu 1997 byla vydána omezená verze první beta verze nového SQL Serveru 7.0. V prosinci téhož roku byla odeslána druhá beta verze produktu několika stovkám uživatelů k testování. Z důvodu přechodu na novou architekturu uživatelé při upgradu verze SQL Serveru požadovali kompletní změnu databází a jejich struktur. Na podporu přechodu zákazníků na novou verzi byl oznámen speciální program 1K Challenge, v jehož rámci mohlo 1000 zákazníků posílat kopie svých databází vývojářům SQL Serveru, aby je přenesli na verzi 7.0. Speciální laboratoř pro kontrolu výsledků portu byla vytvořena ve stejném redmondském kampusu, kde sídlil vývojový tým SQL Serveru. Každý týden od února do srpna 1998 poslalo čtyři nebo pět softwarových společností třetích stran své vývojové týmy na týden do Microsoftu, během kterého v laboratoři testovaly, že jejich produkty budou bez problémů fungovat s SQL Serverem 7.0. Když byly objeveny nějaké problémy, přední vývojáři SQL Serveru je okamžitě řešili a předtím diskutovali o řešení s hosty.
V červnu 1998 byla Beta 3 zveřejněna na speciální webové stránce. Spolu s beta verzí bylo publikováno několik příkladů řešení problémů, které demonstrují nové funkce produktu. Kromě toho byl spuštěn speciální zpravodajský server, aby každý uživatel verze Beta 3 mohl nahlásit nalezené chyby nebo se zeptat vývojářů na nové funkce produktu. Celkem více než 120 000 testerů obdrželo SQL Server 7.0 Beta 3. Tento počet zahrnuje společnosti, které si verzi objednaly přímo prostřednictvím webu společnosti Microsoft, předplatitele MSDN a členy oficiálního programu Microsoft Beta Program (kteří dostávají beta verze všech produktů společnosti Microsoft, jakmile jsou propuštěni).
Před vydáním SQL Server 7.0 se objevily zvěsti, že Microsoft zamýšlí nahradit Access zjednodušenou verzí své relační databáze SQL Server. Společnost je vyvrátila s tím, že nová verze Accessu pro Office 2000 bude mít dva alternativní databázové stroje: Jet, nyní vydané nativní úložné prostředí pro Access, a nový MSDE. Podle informací prezentovaných v té době neměl být MSDE vestavěnou verzí SQL Server, ale technologií pro ukládání dat kompatibilní s SQL Serverem, která má stejnou komponentovou architekturu, což by zase umožnilo vývojářům používat Access jako modul rozhraní pro SQL Server, použijte MSDE k vytváření aplikací, které by se mohly škálovat z desktopové databáze na relačního „velkého bratra“ na SQL Server nebo SQL Server Enterprise [11] .
16. listopadu 1998 na konferenci COMDEX v Las Vegas byl veřejně uvolněn SQL Server 7.0. Novou verzi osobně představil Steve Ballmer . Ve své prezentaci se zaměřil na zlepšení výkonu SQL Server 7.0 oproti předchozí verzi. Upozornil také na problémy související se škálovatelností a dostupností aplikací. Podle něj „prodejci ERP jako Baan, PeopleSoft a SAP budou moci tuto DBMS používat téměř ve všech svých projektech, snad kromě těch největších.“ Podle jeho prognóz by během příštího roku a půl měli nezávislí dodavatelé vytvořit asi 3000 aplikací pro SQL Server 7.0. V době, kdy byla tato verze vydána, existovalo více než tucet jejích úspěšných implementací, včetně takových velkých společností, jako jsou HarperCollins , CBS Sportsline, Comcast Cellular a Southwest Securities. . Navíc 10 z nich již přešlo na novou verzi a Pennzoil , Barnes & Noble a HarperCollins Publishers ji v té době testují již několik měsíců. Zástupci společností Pennzoil, News America (divize HarperCollins) a Barnes & Noble potvrdili zlepšený výkon nové verze. Kromě samotného produktu SQL Server 7.0 představil COMDEX také speciální server pro nepřetržitý provoz SQL Server 7.0 a výrobce ERP systémů Baan Corporation představil sadu aplikací BaanSeries '99, určenou výhradně pro SQL Server 7.0 [11] .
Celý vývojový cyklus podle Douga Lelanda, marketingového manažera pro SQL Server ve společnosti Microsoft, trval 3,5 roku. Také umístil novou verzi jako „první relační DBMS společnosti Microsoft, která podporuje všechny jeho 32bitové operační systémy rodiny Windows“, a Microsoft neměl v plánu uvolnit verze SQL Server pro jiné operační systémy [11] .
Verze 7.0 byla vydána 2. prosince 1998 jako sestavení 7.00.623.07, zatímco zmrazení kódu proběhlo 27. listopadu 1998. Produkt byl k dispozici pro bezplatnou objednávku v lednu 1999.
Mnoho analytiků považovalo vydání verze 7.0 za „významný krok k dobytí trhu podnikových počítačů“. Microsoft podle nich počítal s tím, že se díky přepracované funkcionalitě SQL Server 7.0 stane firemním standardem pro databáze. Přidání online analytického zpracování v SQL Server 7.0 bylo analytiky vnímáno jako vývoj, který „by mohl být nejdůležitějším vývojem na trhu OLAP od jeho založení“. Důvodem bylo, že OLAP systémy byly v té době určeny výhradně pro korporátní segment, a protože strategie Microsoftu zahrnovala vytváření verzí i pro domácí PC, díky tomu se technologie OLAP stávají dostupnými i pro malé firmy, což samo o sobě znamená výraznou popularizaci. OLAP [11] .
Dalším argumentem ve prospěch „standardizace SQL Server 7.0“ byla schopnost SQL Serveru integrovat se se zbytkem podnikových systémů, což bylo kritické v heterogenních vícevrstvých prostředích a přítomnosti heterogenních platforem a datových úložišť. Pro pokrok v této oblasti vyvinul Microsoft interní standardy pro integraci dat, jako jsou OLE DB a ADO , a také spolupracoval s dodavateli softwaru třetích stran. Konkurenti však tyto standardy kritizovali a uvedli, že „některé z těchto standardů jsou čistě interní“, což vážně omezuje jejich schopnost být uplatňovány zákazníky třetích stran. Výrazné kritice byl vystaven i standard OLE DB for OLAP, který Microsoft nabízel jako oborový standard a zároveň jako součást svého wrapperu pro vytváření datových skladů. Takže například Jeff Johns, programový manažer pro marketingové systémy pro správu dat ve společnosti IBM Corporation , označil za hlavní nevýhodu skutečnost, že tento standard vyvinula společnost Microsoft, a nikoli žádné standardizační konsorcium, jak bylo široce praktikováno. Na takovou kritiku zástupci Microsoftu odpověděli, že standard byl vyvinut za účasti více než 60 prodejců datových úložišť [11] .
Analytici poznamenali, že Microsoft měl všechny šance dosáhnout svého cíle. To bylo podpořeno také aktivními pobídkami pro výrobce třetích stran, aby vytvořili software pro SQL Server 7.0, a distribuční model vypadal lépe než u konkurenčních Oracle a IBM, které by v budoucnu mohly umožnit prodej velkoobchodních šarží za nižší cenu a, díky tomu se stát vážným hráčem na podnikovém trhu.databáze [11] .
Plánovalo se celosvětově prodávat novou verzi prostřednictvím prodejců, zpočátku původní anglickou verzi a během následujících dvou měsíců se měla objevit francouzská, německá, španělská a japonská verze. Do konce února 1999 Microsoft plánoval vydat také čínskou verzi. Z hlediska produktových verzí bylo plánováno vydání standardní a podnikové verze ve třech konfiguracích (v závislosti na počtu povolených uživatelů). Kromě toho byla oznámena speciální nabídka, která uživatelům umožňovala upgradovat svůj systém na SQL Server nebo migrovat z konkurenčních databází do 99 dnů od oznámení, přičemž za SQL Server 7.0 zaplatí pouze 99 USD za uživatele [11] .
Analytici spekulovali, že tyto ceny by mohly donutit konkurenty Microsoftu ke snížení jejich tradičně vysokých cen (ačkoli to například společnost Oracle oficiálně odmítla). Analytici byli k nové verzi také spíše skeptičtí, protože se domnívali, že SQL Server 7.0 je určen především pro systémy na low-end databázovém trhu pro Windows NT, zvláště když několik beta testerů potvrdilo, že nová verze plně vyhovuje jejich požadavkům. Například Herb Edelstein, analytik společnosti Two Crows, uvedl, že „nízké ceny stanovené společností Microsoft jsou zaměřeny na odstranění konkurence na tomto trhu“, zatímco „i když vezmeme v úvahu všechny nové funkce, bude SQL Server 7.0 schopen vyřešit pouze část problémů, kterým čelí uživatelé velkých korporací. Betsy Barton, analytička společnosti Gartner Group, se domnívala, že i když si doplňky představené v nové verzi „zaslouží pozornost“, „celková spolehlivost a škálovatelnost systému je stále sporná“. Zástupci společností, ve kterých byla nová verze testována, však produkt nadále charakterizovali pozitivně. Kromě výše zmíněných společností se o produktu pozitivně vyjádřili také Mark Mitchell, systémový konzultant Applied Automation, a Joe Misiazhek, manažer aplikační podpory pro systém používaný na Colorado Community College. Zaznamenali dostupnou cenu produktu, dobrý výkon a relativní snadnost vývoje [11] .
Takové kroky Microsoftu vyvolaly odpor konkurentů. Například společnost Oracle Corporation byla nucena změnit svou prodejní strategii. Podle široce rozšířeného prohlášení musela společnost začít prodávat své DBMS nainstalované na předkonfigurovaných „serverových zařízeních“, které používají zjednodušený operační systém vyvinutý za účasti samotného Oracle. Podle šéfa Oracle Larryho Ellisona měly takové novinky „snížit náklady na vlastnictví databáze Oracle a zároveň posílit konkurenceschopnost produktu v konfrontaci s SQL Serverem od Microsoftu“. V polovině listopadu 1998 Oracle podepsal dohodu se společnostmi Dell, Compaq, Hewlett-Packard a Sun Microsystems o zahájení prodeje serverů do konce prvního čtvrtletí roku 1999. Operační systém nainstalovaný na nových serverech obsahoval komponenty Solaris (v budoucnu měl používat komponenty Linux ) a byl tak jednoduchý, že tato iniciativa byla nazvána Raw Iron (“Bare Iron”). Partneři společnosti Oracle se chystali nabídnout tři typy serverů („malé, střední a velké“, jak je Ellison nazval) předem nakonfigurované pro konkrétní úkoly, jako je e-mail a IFS (Internet File System). Mělo tedy dojít k přechodu od prodeje krabicové verze DBMS k prodeji serverů, jejichž náklady na vlastnictví jsou mnohem nižší. Tato strategie měla podle Ellisona pomoci odlákat některé kupce SQL Serveru [11] .
Stejně jako v předchozích dobách se práce na SQL Serveru po vydání sedmé verze nezastavily. Verze 7.0 neobsahovala všechny původně plánované funkce a kromě toho došlo k několika dalším vývojům, které byly v závěrečných fázích a měly být zahrnuty do příští hlavní verze. Tak začal vývoj dvou verzí: Shilo ( anglicky Shiloh ) - "juniorské" vydání verze 7.0 (relativně řečeno 7.5 analogicky s předchozím vydáním) a Yukon ( anglicky Yukon ) - další hlavní vydání.
Produktoví manažeři serveru SQL Server se zpočátku zdráhali předpovídat popularitu serveru SQL Server 7.0. Důvodem bylo, že toto vydání bylo založeno na kompletně přepsaném kódu serverového enginu, což vedlo mnoho zákazníků k tomu, že jej považovali pouze za první vydání a bylo zřejmé, že mnoho potenciálních zákazníků sedmé verze by raději počkalo na nějakou verzi. druh "pevné verze" nebo alespoň první service pack (service pack). Shiloh byl tedy původně plánován jako druh super servisního balíčku a bylo plánováno zahrnout funkce, které nebyly zahrnuty ve verzi 7.0 kvůli krátké době vývoje, a také opravit všechny chyby nalezené v té době, což bylo příliš objemné. pro obvyklou „nečíslovanou verzi. V souladu s tím bylo plánováno vydání Shiloh nejpozději rok po vydání SQL Server 7.0.
Změnu původního konceptu Shiloh však ovlivnilo několik faktorů najednou. Za prvé, oproti očekávání jen malá část zákazníků pochybovala o nutnosti migrace na verzi 7.0 a prodeje novým zákazníkům předčily jejich nejdivočejší očekávání. Zpětná vazba od zákazníků byla také velmi pozitivní. I po vydání SQL Server 7.0 společnost Microsoft nadále udržovala laboratoř pro vývoj softwaru třetí strany, což zajistilo, že vývojáři neustále získávají zpětnou vazbu a zpětnou vazbu od zákazníků. Nalezené komentáře a chyby byly snadno opraveny obvyklým způsobem a opravná sada pro SQL Server 7.0 byla vydána v květnu 1999 . Druhá opravná sada byla vydána v březnu 2000 . Tím pádem zmizela potřeba super service packu, jak Shiloh původně vypadalo.
Druhým faktorem byly požadavky zákazníků na funkce. Například původně plánovaná implementace referenční integrity pro kaskádové aktualizace a odstraňování nebyla nakonec zahrnuta do SQL Server 7.0. Klienti naopak projevili o takový mechanismus extrémní zájem a požadovali jeho co nejrychlejší realizaci. Kromě toho se objevily četné požadavky na podporu pro rozdělené pohledy a na optimalizaci podpory pro schéma hvězdicového návrhu , které se široce používá v aplikacích skladových zásob .
Dalším faktorem byla konkurence mezi prodejci databází, kteří požadovali, aby příští vydání bylo větší a lepší, než bylo původně plánováno. Velký dopad měla také výzva Million Dollar od Larryho Ellisona z Oracle Corporation , která zdůraznila některé funkce, které již byly dostupné v Oracle, ale stále chybí v SQL Serveru. Přidání takové funkce šlo daleko za rámec jednoduché opravy.
Nakonec padlo rozhodnutí udělat ze Shiloh plnohodnotné hlavní vydání s 18měsíčním vývojovým cyklem, ale se zachováním oficiálního čísla verze 7.5. Počet změn v té době bylo těžké předvídat a jedinou změnou, která se v té době s jistotou věděla, bylo vylepšení kaskádových aktualizací a mazání. Brzy se ukázalo, že vydání již roste nad původní plány. Zároveň se rozrostl i vývojový tým, který se přesunul z hlavního kampusu Microsoftu do části kanceláří budovy dvojčete. Nárůst počtu vývojářů umožnil přidat do produktu velké množství středních a malých vylepšení, aniž by došlo k výraznému posunu v načasování vydání produktu.
Také si vývojáři, kromě úkolů vylepšování a zvyšování funkčnosti, stanovili tzv. „flexibilní zadání“. Například oznámili potřebu dosáhnout 20% nárůstu výkonu pro všechny typy aplikací, ale pro upřesnění úkolu bylo provedeno srovnání s určitými aplikacemi. Jedním z hlavních cílů bylo například zlepšit výkon v benchmarku SAP R/3 Sales and Distribution alespoň o 40 %. K dosažení tohoto úkolu vývojáři provedli speciální změny v optimalizátoru, které přímo ovlivňují požadavky ze SAP, ale zároveň vylepšují požadavky z jiných aplikací. Dne 17. února 2000, na spouštěcí akci Windows 2000 v San Franciscu, byly oznámeny výsledky benchmarku Prodej a distribuce ukazující kapacitu zatížení 6 700 uživatelů, což výrazně překonalo SQL Server 7.0 (4 500 uživatelů) při stejném testu a hardwaru (použili jsme osmiprocesorový stroj s Pentiem III-550). Nárůst produktivity byl tedy 48 %, což znamená, že tento úkol byl splněn.
Po rozhodnutí o prodloužení doby vývoje na 18 měsíců padlo další rozhodnutí o přidání nové funkcionality. Toto rozhodnutí bylo drženo v nejpřísnější tajnosti a nebylo diskutováno ani s mnoha vedoucími pracovníky společnosti Microsoft. Nová funkcionalita nebyla zmíněna ani po vydání první beta verze v listopadu 1999 a byla veřejně představena až v únoru na akci spuštění Windows 2000. Tento tajný projekt s kódovým označením Coyote měl za cíl přidat podporu pro SQL Server 2000 distribuované rozdělené pohledy, což by umožnilo vysokou škálovatelnost při práci s daty. Právě tato funkcionalita umožnila vytvořit světový rekord, který byl vyhlášen v San Franciscu v únoru 2000 . Tyto změny škálovatelnosti byly původně zamýšleny pro vydání po Shiloh, ale protože většina požadovaných komponent již byla na místě, bylo rozhodnuto přidat tuto funkci do reprezentace SQL Server 2000.
První beta verze Shiloh byla vydána pro počáteční zkoušky a testování beta testery v září 1999 a Microsoft brzy oznámil, že nová verze produktu bude oficiálně pojmenována SQL Server 2000. Pro tuto změnu názvu byly dva hlavní důvody. Za prvé, s ohledem na četné a závažné změny v nové verzi bylo nerentabilní vydat ji jako přechodnou verzi (7.5), což znamená, že bylo potřeba nové číslo. Ale za druhé, pokud bude nová verze vydána jako 8.0, pak se ukáže, že z celé rodiny Microsoft BackOffice to bude jediný produkt, který nemá v názvu předponu 2000 . Aby byla zachována jednota názvů produktů, bylo rozhodnuto pojmenovat produkt SQL Server 2000 (v tomto případě interní číslo verze stále vypadalo jako 8.00.194).
Z uživatelského hlediska poskytoval SQL Server 2000 mnohem více možností než předchozí verze. SQL Server 7.0 měl kompletně přepsaný engine, podporu pro nové uložené struktury, metody přístupu k datům, technologie zamykání záznamů, algoritmy obnovy, novou architekturu protokolování transakcí , novou architekturu paměti a optimalizátor. Navzdory tomu všemu byly z pohledu vývojáře nebo DBA jazykové změny a vylepšení v SQL Server 7 minimální. SQL Server 2000 měl řadu jazykových vylepšení a také velké změny dříve zavedených objektů, jako jsou omezení tabulek, pohledy a spouštěče, které potřebovali všichni vývojáři a většina správců databází.
Vzhledem k tomu, že vnitřní změny enginu byly minimální, byly plánovány pouze dvě beta verze. Druhá beta, vydaná v dubnu 2000 , se stala veřejnou beta verzí a byla zaslána tisícům zainteresovaných uživatelů, účastníkům průmyslových konferencí, vývojářům softwaru třetích stran a konzultantům. Vývojový tým zmrazil kód 6. srpna 2000 ve verzi 8.00.194.01 a produkt byl vydán 9. srpna .
Vývoj další verze SQL Serveru s kódovým označením Yukon začal souběžně s vývojem 64bitové verze SQL Server 2000 s kódovým označením Liberty. Liberty byla v podstatě stejná 32bitová verze ve funkčnosti, ale rozdíl byl v mnohem větší škálovatelnosti. Nová funkcionalita měla být implementována jako součást Yukonu.
V červenci 2002 společnost Microsoft v rámci oficiální prezentace svého nového rozhraní .NET Framework oznámila, že příští verze serveru SQL Server s kódovým označením Yukon bude moci využívat možnosti platformy .NET. Konkrétně bylo uvedeno, že by bylo jednodušší spravovat distribuovaná data v Yukonu [12] .
24. dubna 2003 na konferenci v San Franciscu věnované vydání Windows Server 2003 Microsoft oznámil vydání 64bitové verze SQL Server 2000 (dříve známé jako Liberty). Podle zveřejněné tiskové zprávy byla nová verze SQL Server 2000 navržena tak, aby fungovala s 64bitovou verzí Windows Server 2003. Třetím produktem představeným společně s Windows Server 2003 a novou verzí SQL Server 2000 bylo Visual Studio . NET 2003 . Tato trojice produktů byla podle Microsoftu dalším krokem ve vzájemné provázanosti OS, SQL serveru a vývojového prostředí, čímž se přiblížila přechodu na jedinou platformu .NET Framework , která byla v další verzi mnohem plněji implementována. serveru SQL Server. V rámci prezentace Steve Ballmer a Paul Otellini uvedli, že server s nainstalovanou novou verzí SQL Server 2000 vytvořil dva nové rekordy podle výsledků testů neziskové organizace Transaction Processing Performance Council . Stejně jako v předchozích případech byla nová verze předinstalována pro testování hlavními partnery Microsoftu, včetně Cornell University , Information Resources, Inc ( SymphonyIRI Group ), JetBlue Airways , Liberty Medical Supply ( Liberty Medical ) a University Johns Hopkins , na což oficiální zástupci těchto organizací kladně reagovali na nový produkt [13] .
Účelem vydání 64bitové verze byla touha začít obsazovat tu část trhu, která dříve patřila výhradně vysoce výkonným řešením založeným na systémech s operačním systémem UNIX . Přestože funkčnost zůstala v podstatě nezměněna oproti 32bitové verzi, 64bitová verze mohla pracovat s výrazně větším množstvím paměti, ke které měl přístup 64bitový systém Windows Server 2003, díky čemuž se nová verze SQL Server 2000 mohla škálovat. na úroveň výkonných systémů, kterým 32bitová verze nemohla pro svá omezení konkurovat. Kupujícím 32bitové verze byl nabídnut upgrade na novou verzi bez dalších nákladů [13] .
V listopadu 2003 na konferenci PASS v Seattlu mluvili manažeři společnosti Microsoft o nových mechanismech ETL implementovaných v Yukonu, které byly použity k přenosu dříve nashromážděných informací z existujících aplikací do datových skladů. Tyto mechanismy měly být z pohledu Microsoftu jedním z argumentů pro přilákání firemních uživatelů. Architektura SQL Server ETL implementovaná v Yukonu se nazývá Data Transformation Services (DTS). Podle Gordona Mangioneho, viceprezidenta Microsoftu a vedoucího týmu SQL Server Team, měl DTS za cíl implementovat souběžnost, která uživatelům umožňuje současně provádět více komplexních úkolů, jako je překládání dat, jejich čtení a přepisování v jediném vláknu [14]. .
Kromě ETL byl kladen důraz také na zjednodušení konfigurace a správy DBMS a také na zlepšení škálovatelnosti. Konkrétně zástupci Microsoftu uvedli, že například proces zahrnující miliony sloupců dat bude díky zvýšené škálovatelnosti schopen běžet během několika sekund, nikoli minut. Kromě toho bylo plánováno, že nová verze SQL Serveru bude obsahovat funkce, které usnadní vytváření a správu datových skladů a také provádění operací souvisejících s business intelligence. Microsoft slíbil vývojářům nové API , které by podporovalo platformu .NET (a zejména jazyk Visual Basic ), čímž se vyloučila potřeba specifického kódu DTS [14] .
Během konference také Mangione oznámil dokončení Best Practices Analyzer pro SQL Server 2000, který udržuje seznam 70 pravidel společně sestavených vývojáři Microsoftu a uživateli SQL Serveru. Takový seznam měl administrátorům databází zjednodušit proces konfigurace DBMS a pomoci jim vyhnout se nejčastějším chybám. Zároveň byly podporovány funkce zálohování a obnovy po poruchách a také správa databáze a sledování výkonu. Mangione slíbil, že společnost bude tuto sadu nástrojů čtvrtletně aktualizovat [14] .
Verze SQL Serveru, která měla nahradit SQL Server 2005, měla kódové označení Katmai. V období aktivního vývoje se Microsoft extrémně zdráhal sdílet informace o nové verzi. Při prezentaci SQL Server 2005 Paul Flessner (tehdejší viceprezident Microsoftu pro SQL Server business) sebejistě prohlásil, že nová verze bude vydána nejpozději dva roky po vydání SQL Server 2005. V dubnu 2007 však žádná informace o blížícím se vydání produktu, nebo alespoň o začátku jeho beta testování. Rakouský blog na TechNet však zveřejnil informace o Katmai Technology Adoption Program (zkráceně TAP), který měl údajně začít v červnu 2007. Mluvilo se také o tom, že nová verze bude vydána v roce 2008, ale Microsoft v té době tuto informaci nepotvrdil ani nevyvrátil. Některé zdroje spojovaly vydání Katmai s vydáním Longhorn Server a Visual Studio Orcas, proto měla být nová verze podle těchto informací vydána v první polovině roku 2008. Microsoft také odmítl tuto informaci komentovat [15] .
Nicméně někteří novináři, kteří hovořili se zástupci korporace, uvedli, že zvěsti o vydání Katmai v roce 2008 jsou v souladu s interními plány samotného Microsoftu. A odmítnutí korporace zveřejnit jakékoli informace o nové verzi bylo spojeno s přechodem na nový vývojový model, a proto bylo nepravděpodobné, že by Katmai byla vydána na začátku roku 2008. Bylo také zmíněno, že Katmai neobdrží oficiální beta testovací fázi, ale místo toho bude veřejné testování probíhat v rámci programu Community Technology Preview (zkr. CTP). Zároveň se tvrdilo, že někteří zákazníci Microsoftu již v dubnu 2007 měli některé části Katmai na testování, přičemž neměli v rukou celé vydání. Pokud jde o funkčnost nové verze, novináři psali, že Katmai bude pouze vývojem SQL Serveru 2005, a nikoli novou generací produktu, kterým se SQL Server 2005 kdysi stal [15] .
SQL Server 2008 R2 byl oficiálně k dispozici ke koupi 21. dubna 2010.
Koncem roku 2010 Ted Kammert, viceprezident divize Microsoft Business Platform Division, uvedl, že nová verze byla „představena velmi rychle“, konkrétně dva měsíce po vydání produktu „byla stažena přes internet asi 700 000krát. “, což podle něj bylo „nejvyšší číslo pro novou verzi SQL Serveru“ [16] .
Souběžně s tím 30. června 2010 Scott Guthrie na svém blogu oznámil vydání nové mobilní verze SQL Serveru – SQL Server Compact 4.0 , zaměřené především na webové aplikace vytvořené na základě technologie ASP.NET 4 . Jako přednosti nové verze Guthrie vyzdvihl absenci nutnosti instalace programu a také kompatibilitu s .NET Framework API (podpora technologií ADO.NET , Entity Framework , NHibernate aj., možnost pracovat s Visual Studio 2010 a Visual Web Developer 2010 Express ) a nejnovější verze SQL Server a SQL Azure [17] v té době .
Dne 7. července 2010 Ambrish Mishra, vedoucí projektu SQL Server Compact, vydal CTP1 verzi nového SQL Server Compact 4.0 na oficiálním blogu týmu SQL Server CE. Jako inovace (kromě těch, které uvedl Scott Guthrie), zvýšená spolehlivost, vylepšený šifrovací algoritmus SHA 2, kompatibilita s databázovými soubory Compact 3.5, zjednodušená instalace (včetně podpory režimů WOW64 a 64bitových nativních aplikací), snížené využití virtuální paměti , Povolit technologii delegování atributů částečně důvěryhodného volajícího (APTCA), podporu WebMatrix Beta a Visual Studio 2010, podporu stránkovacích dotazů v T-SQL . Verze CTP1 měla zároveň určité problémy (nesprávná odinstalace přes příkazový řádek, problémy s kompatibilitou s aktuální verzí ADO.NET Entity Framework CTP3 atd.) [18] .
Během konference PASS Summit, která se konala od 8. do 11. listopadu 2010 v Seattlu, byly jejím účastníkům (a také předplatitelům MSDN a TechNet) předány kopie verze Denali CTP (po nějaké době byla tato verze zveřejněna na oficiálním webu Microsoft webová stránka). Na samotné konferenci Ted Kammert a Quentin Clark, generální ředitel skupiny Microsoft Database Systems Group, představili novou verzi a hovořili o nové funkci AlwaysOn a technologii VertiPac (součást SQL Server Analysis Services a Data Warehouse). Důraz byl kladen také na vývoj nástrojů business intelligence v nové verzi, interaktivních Webových virtualizačních nástrojů (projekt Crescent) a také vývojářských nástrojů s kódovým označením Juneau [16] .
Dne 22. prosince 2010 oznámil Ambrish Mishra na oficiálním blogu vývojářského týmu vydání SQL Server Compact 4.0 CTP2 a sady nástrojů Visual Studio 2010 pro práci s touto verzí SQL Sever CE [19] .
Finální verze SQL Server Compact 4.0 byla oficiálně vydána na webu Microsoftu 12. ledna 2011, čímž byla dokončena přibližně roční vývojová fáze [20] .
Dne 11. července 2011 vývojový tým SQL Server na svém oficiálním blogu oznámil vydání Community Technology Preview 3 (zkr. CTP3) a první aktualizaci service pack pro SQL Server 2008 R2 [21] . Jako nejvýznamnější inovace (ve vztahu k SQL Server 2008 R2) implementované ve verzi CTP3 nového produktu analytici zaznamenali komponentu SQL Server AlwaysOn pro vytváření záloh databáze, možnost instalovat SQL Server v prostředí Windows Server Core , sloupcový organizace datového úložiště pro urychlení provádění dotazů, vylepšení jazyka T-SQL (zavedení objektů Sequence a okenních funkcí), možnost sledování změn dat (CDC) pro Oracle DBMS, možnost definovat role serveru uživatelem (dříve byly pevně stanoveny), Data Quality Services (znalostní báze), definování pravidel metadat), nový nástroj pro vizualizaci dat s názvem Project Crescent, podpora offline databází (pro přesun mezi místními instancemi SQL Server a SQL Azure) a nový SQL Server Developer Tools s kódovým označením Juneau [22] .
SQL Server 2008 R2 SP1 obsahoval opravy chyb, na které společnost Microsoft obdržela stížnosti od zákazníků prostřednictvím služby Windows Error Reporting, a také některá vylepšení funkcí ( Dynamic Management Views , zvýšená rychlost provádění dotazů pomocí technologie ForceSeek, Data-tier Application Component Framework (zkr. DAC Fx) pro zjednodušení aktualizací databáze, řízení dostupného místa na pevném disku pro PowerPivot) [21] .
Na konci roku 2010 (tedy před vydáním SQL Serveru 2012) hovořil Ted Kammert, viceprezident divize Microsoft Business Platform Division, v rozhovoru o plánech dalšího vývoje produktu (jak SQL Server 2012, tak budoucí verze). Konkrétně Kammert řekl, že práce na SQL Serveru je v kontextu myšlenek Information Platform Vision, což je soubor různých funkcí, které tvoří základ platformy. SQL Server bude i nadále jediným produktem pro desktop, datové centrum a cloud (32bitový i 64bitový). Jednou z prioritních oblastí bude i nadále business intelligence ( angl. business intelligence , BI ). Z pohledu Microsoftu zůstane prioritou v oblasti business intelligence vývoj samoobslužných nástrojů BI a také rozvoj ekosystému cloud computingu . Microsoft navíc při přesunu nástrojů business intelligence do „cloudů“ stále pracuje na implementaci principu konzistence ohledně implementovaných programovacích modelů a nástrojů (sem patří zejména zvýšení schopnosti SQL Server Management Studio pracovat s Prostředí SQL Azure ). Velká pozornost je věnována také problematice škálování DBMS (současně by měl být zvýšen limit systému SQL Server na hranici několika set terabajtů), virtualizaci aplikací v databázovém prostředí a také prostorové reprezentaci dat [ 16] .
Vydání SQL Server 2014 bylo k dispozici 1. dubna 2014.
Vydáno v červnu 2016.
Vydáno v únoru 2017. První verze s podporou Linuxu.
Vydáno v listopadu 2019. Aktuální verze k prosinci 2020.
Microsoft SQL Server | |||||||||
---|---|---|---|---|---|---|---|---|---|
Developerské společnosti | |||||||||
Verze |
| ||||||||
Služby | |||||||||
Utility |
| ||||||||
Rozšíření SQL |
| ||||||||
dodatečně |
|
Systémy pro správu databází (DBMS) | |
---|---|
Klient-server | |
Motory | |
Souborový server |
Databáze | |
---|---|
Koncepty |
|
Objekty |
|
Klíče | |
SQL | |
Komponenty |