H2 Database Engine är en öppen källkod, plattforms och fri grafisk programvara implementeras i Java och utformad för att ge användarna en mycket snabb JDBC API som har en webbaserad konsol och lämnar en mycket liten yta (cirka 1 MB).
Ansökan kommer med en inbäddad läge (i-minne databaser), vilket är snabbare än klient-server-läge. Den har även stöd för krypterade databaser, en ODBC-drivrutin (Open Database Connectivity), fulltextsökning, samt multi version concurrency.Features på en glanceKey funktioner inkluderar en mycket snabb databasmotor, stöd för standarden SQL och JDBC API, klustring support, kraftfulla säkerhetsalternativ, stöd för PostgreSQL ODBC-drivrutinen, i-minne bord, i-minne databaser, diskbaserade databaser, diskbaserade tabeller, temporära tabeller, stöd för skrivskyddade databaser, transaktionsstöd och låsning bordsnivå.
Dessutom har programmet 2-fas-commit support, kostnadsbaserad optimerare, stöd för flera anslutningar, stöd för resultatuppsättningar som är uppdateras och rullbara, stöd för extern resultatet sortering, stöd för stora resultatuppsättningar, stöd för AES (Advanced Encryption Standard) krypterade databaser, SSL (Secure Socket Layer) stöd, samt stöd för SHA-256 krypterade lösenord.
Bland andra funktioner värda att nämna, kan vi enkelt namnge stöd för informations schema och flera scheman, sortering, stöd till roller och användare, förlustfri komprimering, yttre och inre går, vyer inline, skrivskyddade vyer, underfrågor, referensintegritet, check begränsningar, AUTOINCREMENT kolumner, beräknade kolumner och sekvens columns.Supported databas serversCurrently är H2 Database Engine fullt kompatibel med den välkända MySQL, PostgreSQL, IBM DB2, Apache Derby, Microsoft SQL Server, Oracle och hsqldb databasservrar / engines.Under huven och stödde drift systemsBeing skriven i programmeringsspråket Java, är H2 Database Engine projektplattformsoberoende och stöder alla operativsystem där Java Runtime Environment (JRE) är tillgängliga, inklusive GNU / Linux, Microsoft Windows, Mac OS X, Solaris och BSD
Vad är nytt i den här versionen:.
- FÖRKLARA var felaktig för frågor med & quot; NÅGON & quot; eller & quot; NÅGRA & quot; förhållanden.
- Call med & quot; ut & quot; parametrar:. kör samma uttalande två gånger kan resultera i ett undantag (& quot; parameter inte satt & quot;)
- Union frågor:. Dubblerade rader kan återlämnas, om sub-frågor ingår & quot; beställning av & quot;
- geometrin datatyp fungerar nu för användardefinierade funktioner som returnerar en resultatmängd.
- PostgreSQL kompatibilitet:. Det PgServer inte fungerar när inställningen database_to_upper var satt till false
- JdbcDataSource: metod setUrl och getUrl där till som alias för setURL och getURL. Detta bör lösa problem med HikariCP (Hikari-anslutning pool).
- Issue 537: H2 Console: vid lastning schemat, kallar felaktig JDBC där utfärdats, vilket orsakade undantaget & quot; Kolumn PRECISION hittades inte & quot; .
- Förbättrad Geometry bearbetning (fråga 535).
- sorterings kan nu ställas in i databasen URL, även om det finns datatabeller, om samlingen är densamma som den nuvarande sortering.
- Förbättrad Oracle kompatibilitet för CASE NÄR och avkoda.
- Uttalandet & quot; släppa alla objekt & quot; fungerade inte om en tabell beror på en vy via en begränsning.
- Delfrågor eller åsikter med & quot; order av & quot; ett alias uttryck kunde inte köras på grund av en regression introduceras i version 1.3.174.
- Issue 73: MySQL kompatibilitet:. Stöd BYT, patch från Cemo Koc
- Den rumsliga index fungerar nu i MVCC läge när du använder MVStore lagring.
- MVStore: samtidighet problem rättats. API har förenklats.
- Förbättra felmeddelande när släppa ett index som tillhör en begränsning, ange begränsning i felmeddelandet.
- Issue 518: java.sql.Connection.commit () fryser efter LOB modifiering med EXCLUSIVE anslutning
- Issue 517: Skapa eller ersätta view uttalande har ingen effekt på de andra redan befintliga JDBC anslutning
- Support 123L syntax som i Java; exempel:. SELECT (2000000000L * 2)
- Issue 520:. Lägg till stöd för sekvens maxvärde, minvärde och cykla, patch av Daniel Gredler
- Issue 521: ScriptReader bör genomföra stängningsbar
- Issue 524:. RunScript.execute stänger inte sitt uttalande, patch från Gallien
- Lägg till stöd för DB2 & quot; MED UR & quot; klausul, patch från litailang
- Stöd för ON DUPLICATE KEY UPDATE som MySQL med värdena () funktionen för att uppdatera med det värde som skulle sättas in. Patch från Jean-Francois Noel.
- Issue 522:. Behandla tomma strängar som NULL i Oracle kompatibilitetsläge, patch av Daniel Gredler
- Issue 527: Oracle kompatibilitetsläge:. Inkorrekt skala beteende, patch av Daniel Gredler
- Något minska minneskostnaden View metadata.
- Utöka stöd & quot; GRANT ändra någon SCHEMA & quot; att tillåta stipendiat förmåga att manipulera tabeller
- Issue 532: Javadoc för ErrorCode.ROLES_AND_RIGHT_CANNOT_BE_MIXED ser fel
- Issue 528: Lägg Oracle-kompatibel TO_CHAR funktion, patch av Daniel Gredler .
- Issue 534: CREATE ALIAS nocache, Patch av Nicolas Fortin
- Åtgärda ett problem med att lagra Unicode surrogatparen i CLOB kolumner.
- H2-konsol: lägg SKIFT + RETUR & quot; köra utvalda & quot; funktionalitet
- Fix bugg i DB2 syntax & quot; SELECT * FROM test med UR & quot ;, patch från litailang
- Fix bugg i DROP Alla objekt när det handlar om interschema beroenden.
Vad är nytt i version 1.3.174:
- LIRS cache: buggfix för cachar som bara innehåller icke -resident poster.
- För i-minne databaser, frågor med en & quot; grupp av & quot; kolumn som också är en hash index kastade en RuntimeException.
- Förbättrad felmeddelande för vissa syntaxfel.
- Filsystem abstraktion: om de används direkt, vissa filsystem fungerade inte korrekt med skarvade byte buffertar (databasmotorn använder inte dem) .
- Om du vill använda lagringsmotorn MVStore (som fortfarande är i arbete), bifoga & quot ;; mv_store = true & quot; till databasen URL. Använda MVTableEngine när du skapar tabellen inte längre rekommenderas.
- För att kompilera användardefinierade funktioner, javax.tools.JavaCompiler används nu om sådana finns, och inga temporära filer skapas. Detta bör lösa problem när flera H2 databas samtidigt sammanställa samma användardefinierade funktioner. För att avaktivera, systemet system egendom & quot; h2.javaSystemCompiler & quot; till false.
- Samtidigt skapar funktions alias i olika databaser kan resultera i undantaget & quot; javac:. Filen hittades inte & quot;
- Funktionen & quot; regexp_replace & quot; kastade fel sorts undantag om ersättningssträngen var ogiltigt.
- En kontrollpunkt görs nu varje MAX_LOG_SIZE / 2 istället för varje MAX_LOG_SIZE, så att transaktionsloggen inte växer så stor.
- MVStore bordsmotorn: nya inställningen & quot; retention_time & quot; konfigurera tiden att behålla gamla data. Standard är 45 sekunder.
- Metoden TableEngine.createTable () returnerar nu Tabell objekt.
- För skrivskyddade databaser, för spårningsnivån & quot;. Debug & quot ;, trace info skrivs till temp katalogen
- Stänga filen låset kommer nu vänta tills bakgrund tråd stoppas.
- I version 1.3.172, var en prestation regression introduceras vid fastställandet frågan 389 (när det finns en flera kolumner primärnyckel, inte H2 verkar inte alltid välja rätt index). Detta var relaterad till att öka ett index som matchar & quot; beställning av & quot; kolumnlistan (fel index användes i vissa fall).
- Förbättrad rumsliga index och datatyp.
- Utgåva 467:. OSGi Klass Loader (förmåga att skapa hänvisning till klass i andra Classloader, till exempel i en annan OSGi bunt)
- Frågor & quot; grupp av & quot; som innehåller en delfråga med en statistikfunktion return fel resultat i vissa fall.
- Fix bugg i unika och icke-unika hash index som manifesteras som felaktiga resultat när söknyckeln var en annan kardinal typ från bordet indexnyckeln. t.ex. där var INT och den andra var LÅNG
- Bug:. Ändringar i databasstrukturen ledde inte Session frågecachen som ogiltig
- Ny funktion från Davide Cavestro -. Möjligt att använda anpassade Java-objekt serialisering motorer på en per-DB basis
- När du kör Recover verktyget på mycket stora (& gt; 6G) databaser, lite statistik rapporterades med negativa tal .
- Lägg ett CONTAINS_UNCOMMITTED kolumn till sessioner metadatatabellen, att tillåta detektera när oseriösa sessioner skapar stora transaktioner.
- Några små fixar till geometrin stöd, patchar från Nicolas Fortin.
- BNF verktyget och funktionen Komplettera automatiskt exporteras i OSGi, vilket gör det möjligt för smarta redaktörer att göra autocomplete. Patch från Nicolas Fortin.
- Fix DROP alla objekt och DROP SCHEMA i närvaro av bord med beräknad kolumn beroenden.
- Session-tillfällig LOB-s kan ibland ackumuleras, ökar storleken på DB filen tills avstängning. Nu är de rensas ut vid varje begå.
- Det fanns ett fel där en söknyckelindex med mer än en kolumn skulle tyst konverteras till en vanlig index. Det kommer nu att kasta ett undantag.
- Frågestatistik: ny funktion som lagrar de nyaste 100 SQL-frågor avrättade och deras prestandadata. Användbart för att spåra dåligt utför frågor.
- Fix en LOB dödläget mellan läs- och uppdatera LOB-kolumner.
- Stöd JDBC DatabaseMetaData # getClientInfoProperties () metoden, i den meningen att returnera en tom resultat, i syfte att göra WebSphere lycklig.
- Gör Server # openBrowser respektera $ webbläsare miljövariabeln. Lägg & quot; krom & quot; till listan över webbläsare försökt. Patch från Felix Kaiser.
- Fix till org.h2.util.ScriptReader vid hantering oavslutade blockera kommentarer.
- Gör org.h2.util.ScriptReader kasta en bättre undantag vid hantering trasiga skript som genererar extremt stora uttalanden.
- Fix bugg med ALLOW_LITERALS = INGEN, där den återkommande analysera tabellen på insatsen skulle kasta ett undantag. Ett liknande problem var fast i konsolen verktyget.
- Issue 510: Gör org.h2.bnf allmänheten för konsumtion av externa projekt, patch av Nicolas Fortin
- Issue 509: Viktig fix på ValueGeometry, patch av Nicolas Fortin (med vissa justeringar) Gör ValueGeometry # getDimensionCount mer tillförlitlig. Lägg enhetstest för att kontrollera illegal ValueGeometry jämförelse Lägg enhetstest för konvertering av geometri objekt till objekt Lägg valfria export till manifest.mf för JTS Geometri klasser Validera att geometrivärden kan vara representerade i WKB.
- Issue 506: RFE: Inkludera Thread.getName () vid ett dödläge
- lägga till stöd för & quot; GRANT ALTER NÅGON SCHEMA & quot ;, patch av John Yates
Vad är nytt i version 1.3.173:
- Denna version förbättrar MySQL och PostgreSQL kompatibilitet, förbättrar MVStore lagringsmotor, och lägger den nya typen & quot uppgifter, geometri & quot; för rumsliga data.
Vad är nytt i version 1.3.171:
- Säkerhet: TCP-servern inte korrekt begränsa tillgången rättigheter klienter i vissa fall. Detta var speciellt ett problem när du använder flaggan & quot; tcpAllowOthers & quot;.
- H2 Console:. Sessionen timeout kan nu konfigureras med hjälp av systemet egenskapen & quot; h2.consoleTimeout & quot;
- Issue 431: Förbättrad kompatibilitet med MySQL: stöd för & quot; MOTOR = InnoDB charset = UTF8 & quot; när du skapar en tabell.
- Issue 249: Förbättrad kompatibilitet med MySQL i MySQL-läge:. Nu de metoder DatabaseMetaData metoder butiker * Case * Identifierare tillbaka samma som MySQL när du använder MySQL läget
- Issue 434:. H2 Console fungerade inte i Chrome på grund av en felaktig visnings argumentet
- Det fanns en möjlighet att .lock.db filen inte togs bort när databasen stängdes, vilket kan bromsa öppna databasen.
- SQL-skript genereras av & quot; script & quot; Kommandot innehöll inkonsekventa radbrytningar i Windows.
- När du använder spårningsnivå 4 (SLF4J) i serverläge, en katalog & quot; trace.db & quot; och en tom fil skapades på klientsidan. Detta är inte längre görs.
- Optimera IN (...) frågor: det fanns en bugg i version 1.3.170 om den typ av vänster matchade inte den typ av höger sida. Fast.
- Optimera IN (...) frågor: det fanns en bugg i version 1.3.170 för jämförelse av typen & quot; X IN (NULL, NULL) & quot ;. Fast.
- Tidsstämplar med tidszon som skickas som en sträng inte alltid konverteras korrekt. Till exempel & quot; 2012-11-06T23: 00: 00.000Z & quot; omvandlades till & quot; 2012/11/06 & quot; istället för & quot; 2012/11/07 & quot; i tidszonen CET. Tack så mycket till Steve Hruda för rapportering problemet!
- Ny bordsmotorn & quot; org.h2.mvstore.db.MVTableEngine & quot; som internt använder MVStore kvarstå uppgifter. Att prova ut, bifoga & quot ;; DEFAULT_TABLE_ENGINE = org.h2.mvstore.db.MVTableEngine & quot; till databasen URL. Detta är fortfarande väldigt experimentellt, och många funktioner stöds inte ännu. Data lagras i en fil med ändelsen & quot; .mv.db & quot;.
- Ny anslutning inställning & quot; DEFAULT_TABLE_ENGINE & quot; att använda en särskild tabell motor om inget explicit. Detta för att förenkla testa MVStore bordsmotorn.
- MVStore: krypterad butiker stöds nu. Endast standardiserade algoritmer används:. PBKDF2, SHA-256, XTS-AES, AES-128
- MVStore:. Förbättrade API tack vare Simo Tripodi
- MVStore:. Kartorna kan nu döpas
- MVStore:. Lagra filhuvudet även vid slutet av varje bit, vilket resulterar i ett reducerat ytterligare antal skrivoperationer
- MVStore:. En karta implementering som stöder samtidiga operationer
- MVStore: enhetlig undantagshantering; den version ingår i meddelandena.
- MVStore:. Gamla data nu bevaras i 45 sekunder som standard
- MVStore:. Kompress är nu inaktiverad som standard och kan aktiveras på begäran
- Support ALTER TABLE ADD ... EFTER. Patch från Andrew Gaul (argaul at gmail.com). Fixar fråga 401.
- Förbättrad OSGi stöd. H2 registrerar sig nu som en DataSourceFactory tjänst. Fixar fråga 365.
- Lägg ett DISK_SPACE_USED systemfunktion. Fixar fråga 270.
- Fix en kompileringskonstant tvetydighet vid sammanställningen med JDK7, tack vare en lapp från Lukas Eder.
- Stöd släppa ett index för Lucene fritextindex.
- Optimerad prestanda för SELECT ... ORDER BY X LIMIT Y OFFSET Z frågor för i-minne databaser med partiell sort (av Sergi Vladykin).
- Experimentell off-heap minne lagring motor & quot; nioMemFS: & quot; och & quot; nioMemLZF:. & quot ;, förslag från Mark Addleman
- Issue 438: JdbcDatabaseMetaData.getSchemas () stöds inte längre som på 1.3.169 .
- MySQL kompatibilitet: stöd för ALTER TABLE tabellnamn MODIFY [KOLUMN] column columnDef. Patch från Ville Koskela.
- Issue 404:. VISA kolumner från tablename fungerar inte med ALLOW_LITERALS = NUMMER
- Kasta en explicit fel att göra det klart att vi inte stöder TRIGGER kombinationen av SELECT och för varje rad.
- Issue 439:. Utils.sortTopN hanterar inte enda elementuppsättningar
Vad är nytt i version 1.3.170:
- Issue 407: The TriggerAdapter fungerade inte med CLOB och BLOB kolumner.
- PostgreSQL kompatibilitet:. Stöd för datatyper BIGSERIAL och SERIE som ett alias för AUTO_INCREMENT
- Issue 417: H2 Console: webbsession timeout fungerade inte, vilket resulterar i en minnesläcka. Detta var bara ett problem om H2 Console kördes under en lång tid och många sessioner öppnades.
- Issue 412: Köra Server verktyget med bara alternativet & quot; -browser & quot; kommer nu logga en varning.
- Issue 411:. CloseWatcher registreringen inte var samtidighet säkra
- MySQL kompatibilitet: stöd för CONCAT_WS. Tack så mycket till litailang för lappen!
- PostgreSQL kompatibilitet: stöd för UTDRAG (VECKA FRÅN dateColumn). Tack vare Prashant Bhat för lappen!
- Fixat en bugg där vi ibland skulle använda fel unika begränsningen att validera främmande nycklar.
- Support BOM i början av filerna för kommandot runscript
- Fix i att kalla SETX = IDENTITY () där det skulle återvända NULL felaktigt
- Fix ABBA dödläget mellan att lägga ett tvång och H2-Log-Writer tråd.
- Optimera IN (...) avfrågar där värdena är konstanta och av samma typ.
- Återställ verktygs: parametern & quot; tyst & quot; användes inte och är nu bort.
- Fix ConcurrentModificationException när du skapar tabeller och köra VISA TABELLER parallellt. Rapporterad av Viktor Voytovych.
- Serialisering nu jackbar använder systemet egenskapen & quot; h2.javaObjectSerializer & quot ;. Tack vare Sergi Vladykin för lappen!
Vad är nytt i version 1.3.169:
- Standard jar-filen nu sammanställas för Java 6 .
- Den nya jar-filen kommer förmodligen inte hamna i den centrala Maven förvaret i de närmaste veckorna eftersom Sonatype har inaktiv automatisk synkronisering från Sourceforge (som de kallar "legacy sync" nu). Det kommer förmodligen att ta tid innan denna sorteras ut. De H2 jar-filer distribueras till http://h2database.com/m2-repo/com/h2database/h2/maven-metadata.xml och http://hsql.sourceforge.net/m2-repo/com/h2database/h2 /maven-metadata.xml som vanligt.
- En del av dokumentationen och H2 Console har ändrats för att stödja Apples retina display.
- CreateCluster verktyg skulle inte användas om källdatabasen innehöll en CLOB eller BLOB. Den grundläggande orsaken var att TCP servern inte synkroniseras på sessionen, vilket orsakade ett problem när du använder den exklusiva läget.
- Statement.getQueryTimeout (): endast det första samtalet till den här metoden gör sökningar i databasen. Om fråge timeout ändrades på ett annat sätt än att ringa setQueryTimeout kommer denna metod alltid tillbaka det sista värdet. Detta ändrades eftersom Hibernate kallar getQueryTimeout () mycket.
- Issue 416: PreparedStatement.setNString kastar AbstractMethodError. Alla genomförda JDBC fyra metoder som inte bryter kompatibilitet med Java 5 ingår nu i standard jar-filen.
- Issue 414: för vissa funktioner, var de parametrar utvärderades två gånger (till exempel & quot; char (NEXTVAL (..)) & quot; sprang & quot; NEXTVAL (..) & quot; två gånger) .
- ResultSetMetaData metoder getSchemaName och getTableName kunde återvända null istället för & quot; & quot; (En tom sträng) som anges i JDBC API.
- Inkom kompatibilitet för & quot; SET NAMN & quot; fråga i MySQL kompatibilitetsläge.
Vad är nytt i version 1.3.168:
- Meddelandet & quot; Transaktionslogg kunde inte trunkeras & quot ; var ibland skrivs till .trace.db fil även om det var inga problem trunkera transaktionsloggen.
- Nytt system egendom & quot; h2.serializeJavaObject & quot; (Default: true). Som gör att inaktivera serialisering Java-objekt, så att föremålen compareTo och toString metoder kan användas
- Dylan har översatt H2 Console verktyget koreanska. Tack så mycket!
- Exekvera uttalandet CREATE INDEX IF redan finns om index redan existerar inte längre misslyckas för en skrivskyddad databas.
- MVCC: samtidigt uppdatera en rad kan resultera i raden att visas raderas i den andra anslutningen, om det finns flera unika index (eller en primärnyckel och minst en unikt index). Tack så mycket till Teruo för lappen!
- Fulltext sökning:. I minnet Lucene-index stöds nu
- Fulltext ökning: UUID primärnycklar stöds nu .
- Apache Tomcat 7.x kommer nu längre logga en varning vid lossningen av webbapplikation, om du använder en anslutning pool.
- H2 Console: stödja Midori webbläsaren (för Debian / hallon Pi)
- När du öppnar en fjärrsession, inte öppna en temporär fil om spårningsnivån sätts till noll
- Använd HMAC för autentisering fjärr LOB id, tar bort behovet av att upprätthålla en cache, och att ta bort gränsen för antalet LOB per sökresultatet.
- H2 Console: HTML och XML-dokument kan nu redigeras i en uppdateringsbar resultatet. Det finns (begränsad) stöd för redigering med flera linjer dokument.
Vad är nytt i version 1.3.164:
- Uppdatera ett resultat som i en utlösare stöds nu .
Vad är nytt i version 11.3.162:
- Följande systemegenskaper stöds inte längre: h2 .allowBigDecimalExtensions, h2.emptyPassword, h2.minColumnNameMap, h2.returnLobObjects, h2.webMaxValueLength.
- När du använder en VPN, starta en H2-server inte fungerar (för vissa VPN-programvara).
- Oracle kompatibilitet:. Stöd för DECODE (...)
- Lucene textsökning: skapa ett index är nu snabbare om tabellen redan innehåller data. Tack så mycket till Angel Leon från Frostwire Team för patch!
- Uppdatera rapporter till en kolumnlista inom parentes inte funge om listan innehåller endast en kolumn. Exempel:. Uppdateringsprovuppsättning (id) = (id)
- Läs skyddade databaser i en zip-fil fungerade inte när du använder alternativet -baseDir.
- Issue 334:. SimpleResultSet.getString nu även fungerar för CLOB kolumner
- Underfrågor med en sammanlagd fungerade inte alltid. Exempel: välj (välj count (*) från test där a = ta och b = 0) från prov t grupp efter en
- Server:. I vissa (teoretiska) fall, undantag när du stänger anslutningen ignorerades
- Server.createTcpServer, createPgServer, createWebServer:. Ogiltiga argument nu upptäcks
- selektivitet LOB-kolumner är inte längre beräknas eftersom index på LOB-kolumner stöds inte (men detta bör ha liten inverkan på prestanda, eftersom selektivitet beräknas från hash-kod och inte data).
- Ny experimentella system egendom & quot; h2.modifyOnWrite & quot ;: när aktiverad, är databasfilen endast modifierad när du skriver till databasen. När den är aktiverad är serialiserad filen låset mycket snabbare för skrivskyddade verksamhet.
- En NullPointerException kunde inträffa i TableView.isDeterministic för ogiltiga vyer.
- Issue 180: när deserializing föremål, sammanhanget klassladdaren används i stället för standardklassladdaren om systemet egenskapen & quot; h2.useThreadContextClassLoader & quot; är inställd. Tack så mycket till Noah Fontes för lappen!
- När du använder den exklusiva läget kunde LOB operationer orsaka tråden att blockera. Detta påverkade också CreateCluster verktyget (när man använder BLOB eller CLOB data).
- optimering för & quot; grupp av & quot; fungerade inte korrekt om gruppen genom kolonnen alias i SELECT-listan.
- Issue 326: förbättrat stöd för stora och små bokstäver (blandad fallet) identifierare utan citattecken när du använder DATABASE_TO_UPPER = FALSK .
Krav :
- Java 2 Standard Edition Runtime Environment
Kommentarer hittades inte