Služba SFDatabases.Database

Služba Database poskytuje přístup k databázím, a to jak vestavěným, tak popsaným v dokumentech Base. Pomocí metod této služby lze:

Každá instance služby Database se vztahuje k jediné databázi a nabízí přístup k jejím tabulkám, dotazům a datům. Služba nenabízí přístup k formulářům a sestavám v dokumentu Base.

note

Služba a databáze spolu komunikují pouze prostřednictvím SQL.


SQL příkazy je možné spouštět v přímém nebo nepřímém režimu. V přímém režimu se příkaz předává databázovému enginu bez jakékoliv kontroly syntaxe.

Poskytnutá rozhraní zahrnují jednoduché seznamy tabulek a dotazů a přístup k datům databáze.

tip

Chcete-li mít SQL příkazy čitelnější, můžete názvy tabulek, dotazů a polí uzavřít do hranatých závorek místo do jiných znaků, které mohou být specifické pro určité RDBMS (Relational Database Management System).


Volání služby

Syntaxe:

Následující část kódu ukazuje, jak k databázi přistupovat pomocí služby Database.


        Dim myDatabase As Object
        Set myDatabase = CreateScriptService("SFDatabases.Database", [FileName], [RegistrationName], [ReadOnly], [User, [Password]])
        '   ... Spouštění dotazů, SQL příkazů, ...
        myDatabase.CloseDatabase()
    

Parametry:

FileName: Název souboru aplikace Base. Musí odpovídat zápisu SF_FileSystem.FileNaming.

RegistrationName: Název zaregistrované databáze. Používá-li se název souboru, neměl by být tento argument uveden.

Platí to i naopak: pokud je uveden argument RegistrationName, argument FileName by již neměl být zadán.

ReadOnly: Určuje, zda bude databáze otevřena pouze pro čtení (výchozí = True).

User, Password: Další parametry spojení s databázovým serverem.

note

Tato služba je plně podporována v jazycích Basic i Python. Všechny příklady jsou uvedeny v programovacím jazyce Basic a lze je snadno převést na Python.


Přístup k databázím pomocí služby UI

K databázi přiřazené k dokumentu Base je možné přistupovat také pomocí služby ScriptForge.UI, jak ukazuje následující příklad:


        Dim myDoc As Object, myDatabase As Object, ui As Object
        Set ui = CreateScriptService("UI")
        Set myDoc = ui.OpenBaseDocument("myDb.odb")
        ' Níže jsou uvedeny uživatel a heslo, jsou-li potřeba
        Set myDatabase = myDoc.GetDatabase()
        '   ... Spouštění dotazů, SQL příkazů, ...
        myDoc.CloseDocument()
    
tip

Metoda GetDatabase z výše uvedeného příkladu je součástí služby ScriptForge Base.


Vlastnosti

Název

Pouze pro čtení

Typ

Popis

Queries

ano

pole řetězců (String)

Seznam uložených dotazů.

Tables

ano

pole řetězců (String)

Seznam uložených tabulek.

XConnection

ano

XConnection

Objekt UNO představující aktuální spojení s databází.

XMetaData

ano

XDatabaseMetaData

Objekt UNO představující metadata popisující atributy databázového systému.


Seznam metod služby Database

CloseDatabase
DAvg
DCount

DMin
DMax
DSum

DLookup
GetRows
RunSql


CloseDatabase

Zavře aktuální spojení s databází.

Syntaxe:


       myDatabase.CloseDatabase()
     

DAvg, DCount, DMin, DMax, DSum

Vypočítá zadanou agregační funkci pro pole nebo výraz příslušející k tabulce.

Volitelně lze zadat SQL klauzuli WHERE, která před agregační funkcí použije na data filtr .

Syntaxe:


        myDatabase.DAvg(Expression As String, TableName As String, [Criteria As String]) As Variant
    

Parametry:

Expression: SQL příkaz s názvy polí uzavřenými v hranatých závorkách.

TableName: Název tabulky (bez hranatých závorek).

Criteria: Klauzule WHERE bez klíčového slova "WHERE", názvy polí jsou uzavřeny v hranatých závorkách.

Příklad:

V následujícím příkladu se předpokládá existence souboru Employees.odb obsahujícího tabulku EmployeeData.


      GlobalScope.BasicLibraries.LoadLibrary("ScriptForge")
      Dim myDB as Variant
      Set myDB = CreateScriptService("Database", "~/Databases/Employees.odb")
      ' Zjistí počet zaměstnanců v tabulce
      MsgBox myDB.DCount("[ID]", "EmployeeData")
      ' Vrátí součet všech platů v tabulce
      MsgBox myDB.DSum("[Salary]", "EmployeeData")
      ' Níže jsou uvedeny příklady filtrování tabulek
      MsgBox myDB.DCount("[ID]", "EmployeeData", "[Position] = 'Manager'")
      MsgBox myDB.DCount("[ID]", "EmployeeData", "[Position] = 'Sales' AND [City] = 'Chicago'")
      MsgBox myDB.DCount("[ID]", "EmployeeData", "[FirstName] LIKE 'Paul%'")
    

DLookup

Vyhodnotí SQL výraz pro jediný záznam vrácený klauzulí WHERE definovanou v parametru Criteria.

Jestliže dotaz vrátí více záznamů, uvažuje se pouze první z nich. Parametrem OrderClause určíte, jak se mají výsledky řadit.

Syntaxe:


        myDatabase.DLookup(Expression As String, TableName As String, [Criteria As String], [OrderClause As String]) As Variant
    

Parametry:

Expression: SQL příkaz s názvy polí uzavřenými v hranatých závorkách.

TableName: Název tabulky (bez hranatých závorek).

Criteria: Klauzule WHERE bez klíčového slova "WHERE", názvy polí jsou uzavřeny v hranatých závorkách.

OrderClause: Klauzule ORDER BY bez klíčových slov "ORDER BY". Názvy polí by měly být uzavřeny v hranatých závorkách.

Příklad:


        MsgBox myDB.DLookup("[FirstName]", "EmployeeData", Criteria := "[LastName] LIKE 'Smith'", OrderClause := "[FirstName] DESC")
        MsgBox myDB.DLookup("[Salary]", "EmployeeData", Criteria := "[ID] = '3'")
        MsgBox myDB.DLookup("[Quantity] * [Value]", "Sales", Criteria := "[SaleID] = '5014'")
    

GetRows

Uloží do dvourozměrného pole obsah tabulky nebo výsledek dotazu SELECT či SQL příkazu. První index tohoto pole odpovídá řádkům, druhý index sloupcům.

Pro počet vrácených řádků lze stanovit horní limit. Volitelně mohou být do prvního řádku pole vloženy názvy sloupců.

Vrácené pole bude prázdné, pokud nejsou vráceny žádné řádky a zároveň není požadováno záhlaví sloupců.

Syntaxe:


        myDatabase.GetRows(SQLCommand As String, [DirectSQL As Boolean], [Header As Boolean], [MaxRows As Long]) As Variant
    

Parametry:

SQLCommand: Název tabulky nebo dotazu (bez hranatých závorek) nebo SQL příkaz SELECT.

DirectSQL: Je-li True, SQL příkaz se odešle databázovému enginu bez předchozí analýzy. Výchozí je False. U tabulek se tento argument ignoruje. U dotazů se použije taková možnost, jaká byly nastavena při definování dotazu.

Header: Je-li True, bude první řádek vráceného pole obsahovat záhlaví sloupců.

MaxRows: Maximální počet vrácených řádků. Výchozí hodnota je nula, což znamená, že počet vrácených řádků není omezen.

Příklad:

Níže je několik příkladů použití metody GetRows:


        Dim queryResults as Variant
        ' Vrátí všechny řádky tabulky se záhlavím sloupců
        queryResults = myDB.GetRows("EmployeeData", Header := True)
        ' Vrátí prvních 50 záznamů o zaměstnancích seřazených podle pole 'FirstName'
        queryResults = myDB.GetRows("SELECT * FROM EmployeeData ORDER BY [FirstName]", MaxRows := 50)
    

RunSql

Provede akci z SQL příkazu, kterou může být vytvoření tabulky či vložení, aktualizace nebo smazání záznamů.

Metoda vrátí v případě úspěšného provedení True.

tip

Pokud byla databáze otevřena v režimu pouze pro čtení, bude metoda RunSql zamítnuta s chybovou zprávou.


Syntaxe:


        myDatabase.RunSql(SQLCommand As String, [DirectSQL As Boolean]) As Boolean
    

Parametry:

SQLCommand: Název dotazu (bez hranatých závorek) nebo SQL příkazu.

DirectSQL: Je-li True, SQL příkaz se odešle databázovému enginu bez předchozí analýzy (výchozí = False). U dotazů se použije taková možnost, jaká byly nastavena při definování dotazu.

Příklad:


        myDatabase.RunSql("INSERT INTO [EmployeeData] VALUES(25, 'Smith', 'John')", DirectSQL := True)
    
warning

Všechny procedury nebo identifikátory knihovny ScriptForge, které jsou uvozeny podtržítkem "_", jsou určeny pro interní použití. Není zamýšleno je používat v makrech Basicu.