terça-feira, 10 de julho de 2007

Verificando se um registro existe (EXISTS function)


Se você precisar saber se um registro existe, a maneira mais comum é a execução do comando abaixo. Se a variável :idexists for maior que zero, o registro existe. (Este é um exemplo de Stored Procedure):

SELECT count(*) FROM company WHERE companyid = :id INTO :idexists;

Mas, o jeito certo de fazer isso é usar a função EXISTS(). Se você usar COUNT(*) o Firebird vai olhar todos os itens para validar a condição (i.e.
companyid = :id).

Se você usar a função EXISTS() o Firebird vai parar de procurar assim que achar um registro que atenda a condição. Isso é muito mais rápido.
idexists = 0;
SELECT 1 FROM rdb$database WHERE EXISTS(SELECT * FROM company WHERE companyid = :id) INTO :idexists;


Date Functions

Algumas funções interessantes de Data e Hora no Firebird.
Leia mais no site: Ivan Prenosil's site

Dia da semana
- Day of week (Formato americano: Semanas iniciam no Domingo, Domingo é 0):

EXTRACT(WEEKDAY FROM D)

Dia da semana - Day of week (Formato ISO 8601: a semana inicia na segunda, Segunda é 1):
EXTRACT(WEEKDAY FROM D-1)+1

Primeiro dia do mês:

D - EXTRACT(DAY FROM D) + 1;

Último dia do mês:

D - EXTRACT(DAY FROM D) + 33 - EXTRACT(DAY FROM D - EXTRACT(DAY FROM D) + 32)

Número de dias no mês:
EXTRACT(DAY FROM (D - EXTRACT(DAY FROM D) + 32 - EXTRACT(DAY FROM D - EXTRACT(DAY FROM D) + 32))

Semana do ano (ISO 8601) stored procedure:

CREATE PROCEDURE YearWeek (D DATE)
RETURNS (WEEK_NO VARCHAR(8)) AS
DECLARE VARIABLE W INTEGER; /* week number */
DECLARE VARIABLE Y INTEGER; /* year the week belongs to */
BEGIN
W = (EXTRACT(YEARDAY FROM D) - EXTRACT(WEEKDAY FROM D-1) + 7) / 7;
Y = EXTRACT(YEAR FROM D);

IF (W=0) THEN BEGIN
Y = Y - 1;
D = D - EXTRACT(YEARDAY FROM D) - 1; /* last day of previous year; D is used as temporary variable here */
W = (EXTRACT(YEARDAY FROM D) - EXTRACT(WEEKDAY FROM D-1) + 7) / 7;
END
ELSE
IF (W=53 AND 4>EXTRACT(WEEKDAY FROM (D - EXTRACT(DAY FROM D) + 31))) THEN BEGIN
Y = Y + 1;
W = 1;
END

/* This is just formatting; you may prefer to make W and Y return parameters instead. */
IF (W<10) THEN WEEK_NO = '0'; ELSE WEEK_NO = '';
WEEK_NO = Y '/' WEEK_NO W;
SUSPEND;
END

Ano bisexto - stored procedure:

CREATE PROCEDURE Is_LeapYear (D DATE) RETURNS (LY INTEGER) AS
BEGIN
IF ( 2 = EXTRACT(MONTH FROM (D - EXTRACT(YEARDAY FROM D) + 59)) ) THEN
LY = 1; /* leap year */
ELSE
LY = 0; /* normal year */
END


quarta-feira, 18 de abril de 2007

Lançada a versão Alpha do Firebird 2.1

Acaba de ser disponibilizado para download a primeira versão Alpha do Firebird 2.1. Essa versão traz inúmeras novidades, entra elas o monitoramento de queries, tabelas temporárias, etc. Os interessados em testar já podem baixar os kits de instalação.

Para baixar
clique aqui.
Para ler o
Firebird 2.1 Alpha 1 Notes (Português).

sábado, 17 de março de 2007

Firebird Update


Índice

Veja a Tabela CADASTRO abaixo:

NOME ENDERECO TELEFONE CIDADE
FABIANA RUA SERGIPE, 233 222 5534 BELO HORIZONTE
SUELI RUA DA BAHIA, 1234 339 1100 BELO HORIZONTE
ALESSANDRA AV. AFONSO PENA, 600 465 2211 BELO HORIZONTE
WAGNER AV. PAULISTA, 200 211 1213 SAO PAULO
RIVA RUA MARIANA, 428 550 1133 FORTALEZA
REGINA AV. CRISTOVAO COLOMBO, 4000 600 2299 PORTO ALEGRE

Usando o comando Update:
O comando Update, altera os campos da sua tabela.

Update Cadastro
set nome = "JOSE";
Faça um select, e voce obterá o seguinte resultado:

NOME ENDERECO TELEFONE CIDADE
JOSE RUA SERGIPE, 233 222 5534 BELO HORIZONTE
JOSE RUA DA BAHIA, 1234 339 1100 BELO HORIZONTE
JOSE AV. AFONSO PENA, 600 465 2211 BELO HORIZONTE
JOSE AV. PAULISTA, 200 211 1213 SAO PAULO
JOSE RUA MARIANA, 428 550 1133 FORTALEZA
JOSE AV. CRISTOVAO COLOMBO, 4000 600 2299 PORTO ALEGRE

Observe que se voce não define o registro que deseja alterar,
a query mudará todos os nomes para JOSE.
Para voce alterar somente um registro, voce deverá incluir uma condição:

Update Cadastro
set nome = "JOSE" where nome = "RIVA";
Faça um select, e voce obterá o seguinte resultado:

NOME ENDERECO TELEFONE CIDADE
FABIANA RUA SERGIPE, 233 222 5534 BELO HORIZONTE
SUELI RUA DA BAHIA, 1234 339 1100 BELO HORIZONTE
ALESSANDRA AV. AFONSO PENA, 600 465 2211 BELO HORIZONTE
WAGNER AV. PAULISTA, 200 211 1213 SAO PAULO
JOSE RUA MARIANA, 428 550 1133 FORTALEZA
REGINA AV. CRISTOVAO COLOMBO, 4000 600 2299 PORTO ALEGRE


Firebird Insert


Índice
Veja a Tabela CADASTRO Abaixo:

NOME ENDERECO TELEFONE CIDADE
FABIANA RUA SERGIPE, 233 222 5534 BELO HORIZONTE
SUELI RUA DA BAHIA, 1234 339 1100 BELO HORIZONTE
ALESSANDRA AV. AFONSO PENA, 600 465 2211 BELO HORIZONTE
WAGNER AV. PAULISTA, 200 211 1213 SAO PAULO
RIVA RUA MARIANA, 428 550 1133 FORTALEZA
REGINA AV. CRISTOVAO COLOMBO, 4000 600 2299 PORTO ALEGRE


Usando o comando Insert:
O comando Insert, insere novos dados na tabela.

Insert into Cadastro
values ("CARLOS","RUA ICARAI, 890","339 1212","BELO HORIZONTE");

Voce vera o resultado, fazendo um select:
Select * from Cadastro;
Resultado:

NOME ENDERECO TELEFONE CIDADE
FABIANA RUA SERGIPE, 233 222 5534 BELO HORIZONTE
SUELI RUA DA BAHIA, 1234 339 1100 BELO HORIZONTE
ALESSANDRA AV. AFONSO PENA, 600 465 2211 BELO HORIZONTE
WAGNER AV. PAULISTA, 200 211 1213 SAO PAULO
RIVA RUA MARIANA, 428 550 1133 FORTALEZA
REGINA AV. CRISTOVAO COLOMBO, 4000 600 2299 PORTO ALEGRE
CARLOS RUA ICARAI, 890 339 1212 BELO HORIZONTE

Firebird Select

Índice
Usando o comando Select:
O comando Select, seleciona os dados especificados da tabela.
Quando voce usa *, selecionará todos os campos da tabela.
Voce pode selecionar campos determinados também.

Select * from Cadastro;
Resultado:

NOME ENDERECO TELEFONE CIDADE
FABIANA RUA SERGIPE, 233 222 5534 BELO HORIZONTE
SUELI RUA DA BAHIA, 1234 339 1100 BELO HORIZONTE
ALESSANDRA AV. AFONSO PENA, 600 465 2211 BELO HORIZONTE
WAGNER AV. PAULISTA, 200 211 1213 SAO PAULO
RIVA RUA MARIANA, 428 550 1133 FORTALEZA
REGINA AV. CRISTOVAO COLOMBO, 4000 600 2299 PORTO ALEGRE

Selecionando alguns itens:

Select nome, endereço from cadatro;
Resultado:

NOME ENDERECO
FABIANA RUA SERGIPE, 233
SUELI RUA DA BAHIA, 1234
ALESSANDRA AV. AFONSO PENA, 600
WAGNER AV. PAULISTA, 200
RIVA RUA MARIANA, 428
REGINA AV. CRISTOVAO COLOMBO, 4000


Tutorial de SQL


Structure Query Language (SQL)
  1. Para acesso a um banco de dados relacional, é necessário uma linguagem. A SQL é uma linguagem usada pela maioria dos bancos de dados relacionais.

  2. É uma linguagem baseada no inglês, fácil de escrever, ler e entender.

  3. SQL tem como características, a economia de tempo, flexibilidade e segurança na manutenção de bancos de dados.

  4. Existem pequenas diferenças da linguagem, em alguns bancos.
    1. No VisualFox por exemplo, quando o comando ocupa mais de uma linha, devemos colocar ponto e vírgula no final de cada linha, e no final do comando somente um enter.
    2. No oracle, ao contrário, devemos colocar um ponto e vírgula somente no final do comando, mesmo que este ocupe mais de uma linha.
    3. Estou usando a nomenclatura do Oracle e/ou FireBird, nestes exemplos.
1. Funções definidas pelo padrão SQL:
  • SELECT
  • INSERT
  • WHERE
  • UPDATE
  • DELETE
  • CREATE
  • ALTER
  • DROP
  • DISTINCT
  • ORDER BY
  • GROUP BY
  • SUM
  • MAX
  • MIN
  • AVG
  • JOIN
  • UNION
  • SUBQUERY
  • ALIAS
  • CONCATENACAO
  • NVL
  • BETWEEN
  • IN

Índice

  1. Introdução
  2. Select
  3. Insert
  4. Update
  5. Delete
  6. Where
  7. Create Table
  8. Alter Table
  9. Drop Table
  10. Distinct
  11. Order By
  12. Group By
  13. SUM
  14. MAX
  15. MIN
  16. AVG
  17. UNION
  18. Sub-Query
  19. Alias
  20. Concatenação
  21. NVL - Oracle
  22. Between
  23. IN



quarta-feira, 14 de março de 2007

DB Extract 2005 v.2.2 released

IB/FB Product News

03/13/2007

DB Extract 2005 v.2.2 released

We are pleased to announce new version of DB Extract 2005 - the powerful utility creating database backups in a form of SQL scripts for SQL Server, MySQL, PostgreSQL, InterBase/Firebird, Oracle and DB2 databases.

What’s new in DB Extract version 2.2?

  1. DB Extract for Oracle released. UTF-8 and SSH tunneling support implemented.
  2. DB Extract for DB2 released.
  3. Objects extraction algorithm considering object dependencies has been improved (ALL)
  4. Considerably increased data extraction speed (ALL)
  5. SSH tunneling support is improved: Private Key support for SSH authentication is implemented (IB/FB, MySQL, PostgreSQL, Oracle)
  6. Extraction of BLOBs is now possible (IB/FB, MS SQL, PostgreSQL)
  7. Extraction of Arrays is now possible (IB/FB, PostgreSQL)
  8. “Delete records before insert” option now uses the TRUNCATE command to empty tables instead of DELETE command (MS SQL).
  9. Additional extract options implemented (ALL)
  10. More user-friendly wizard interface (ALL).

You can download DB Extract 2.2 from the following links:
DB Extract 2005 for MySQL:
http://www.sqlmanager.net/products/mysql/extract/download

DB Extract 2005 for PostgreSQL:
http://www.sqlmanager.net/products/postgresql/extract/download

DB Extract 2005 for SQL Server:
http://www.sqlmanager.net/products/mssql/extract/download

DB Extract 2005 for InterBase/Firebird:
http://www.sqlmanager.net/products/ibfb/extract/download


DB Extract 2005 for Oracle:
http://www.sqlmanager.net/products/oracle/extract/download

DB Extract 2005 for DB2:
http://www.sqlmanager.net/products/db2/extract/download

We hope you'll enjoy working with our products.

© 1999-2007 EMS Database Management Solutions, Inc. All rights reserved.

quinta-feira, 8 de março de 2007

Data Import v.3.0 released

Data Import v.3.0 released

We are pleased to announce new version of EMS Data Import, a powerful tool to import your data quickly from MS Excel 97-2007, MS Access, DBF, XML, TXT, CSV, MS Word 2007, ODF and HTML files.

EMS Data Import version 3.0 is now available and can be downloaded from the download pages:

We have also released new Data Import for Oracle. You can learn more at the product info page and download the free trial version.

Upgrade to Data Import version 3.0

The upgrade fee will normally be 50% of the standard product price.

All customers who purchased Data Import within 60 days of the major upgrade release are eligible for a free major upgrade. However, there is a small fee for processing the upgrade request and generating a new registration key.

We would like to bring it to your attention that from this version on the EMS Data Import is sold with Maintenance under EMS Software Maintenance Program (read full information on Maintenance at our Maintenance FAQ). One year of Maintenance is already included in Data Import for free!

What’s new in Data Import version 3.0

  1. The new “Native” method of import is added which includes two algorithms – Single Commands and Batch Insert. Single Commands mode serves to generate and execute single SQL commands on the server; whereas Batch Insert uses native commands for a particular server: BULK INSERT (SQL Server), LOAD DATA INFILE (MySQL) and COPY (PostgreSQL). With the help of Native mode your data can be imported dozen (!) times faster compared to Universal mode which was used in the previous versions.
  2. Unicode support. Now you are able to import Unicode data (for SQL Server, MySQL, PostgreSQL).
  3. Import from new formats is available now:
    • MS Excel 2007
    • MS Word 2007
    • HTML
    • Generic XML
    • Open Document Format (Open Document Text and Open Document Spreadsheet)
  4. Now there is a short field type description next to field names that appear in different lists. This option is enabled by default. When necessary, it can be disabled from Tools>Preferences.
  5. Utility source code significantly optimized, work speed increased.
  6. Identity fields support implemented (for SQL Server).
  7. Ability to import data from text files containing TAB symbols as a separator is added.
  8. Other small improvements and bugfixes.
We hope you'll enjoy working with our products!

© 1999-2007 EMS Database Management Solutions, Inc. All rights reserved.
Thank you for choosing EMS!

segunda-feira, 26 de fevereiro de 2007

ISQL - Firebird Interactive SQL Tool

ISQL is a command-line tool for interactive SQL access to databases. It can also be used to perform administrative tasks in command-line environments (like (metadata) updates via a batch file).

General Syntax

isql <options> [<database>]

or
isql -?


Options

-a(ll)
Extract metadata incl. legacy non-SQL tables
-b(ail)
Bail on errors (set bail on)
-c(ache) <num>
Number of cache buffers
-ch(arset) <charset>
Connection Character Set (set names)
-d(atabase) <database>
Database name to put in script creation
-e(cho)
Echo commands (set echo on)
-ex(tract)
Extract metadata
-i(nput) <filename>
Process SQL script file (set input)
-m(erge)
Merge standard error
-m2
Merge diagnostic
-n(oautocommit)
No autocommit DDL (set autoddl off)
-now(arnings)
Do not show warnings
-o(utput) <filename>
Output file (set output)
-pag(elength) <size>
Page Length
-p(assword) <password>
Connection Password
-q(uiet)
Do not show the message "Use CONNECT..."
-r(ole) <role>
Role Name
-r2 <role>
Role (uses quoted identifier)
-s(qldialect) <dialect>
SQL Dialect (set sql dialect)
-t(erminator) <term>
Command Terminator (set term)
-u(ser) <user>
User Name
-x
Extract Metadata
-z
Show Program and Server Version


Interactive Mode

ISQL enters an interactive mode. Command lines start with a SQL> prompt, continuing lines with a CON> prompt.
NOTE that every command has to be terminated by a semi-colon (;).

C:ProgrammeFirebird2bin>isql
Use CONNECT or CREATE DATABASE to specify a database
SQL> connect elias:apqp user sysdba password masterkey;
Database: elias:apqp, User: sysdba
SQL> _

You can now enter DDL, DML or special ISQL commands.

You can also specify the database directly in the isql call:
C:ProgrammeFirebird2bin>isql -user SYSDBA -password masterkey elias:apqp

Database: elias:apqp, User: SYSDBA
SQL> exit;

ISQL Commands

You can get a list of commands by calling the HELP; command.

BLOBDUMP <blobid> <file> 
Dump BLOB to a file
BLOBVIEW <blobid> 
View BLOB in text editor
EDIT [<filename>] 
Edit SQL script file and execute
EDIT 
Edit current command buffer and execute
HELP 
Display Help
HELP SET
Display Help for the SET command
INput <filename> 
Take input from the named SQL file
OUTput [<filename>] 
Write output to named file
OUTput 
Return output to stdout
SET <option> 
Set option. Use HELP SET for a complete list
SHELL <command> 
Execute Operating System command in sub-shell
SHOW <object> [<name>] 
Display system information on a database object. <object> can be: CHECK, DATABASE, DOMAIN, EXCEPTION, FILTER, FUNCTION, GENERATOR,GRANT, INDEX, PROCEDURE, ROLE, SQL DIALECT, SYSTEM, TABLE, TRIGGER, VERSION, VIEW
EXIT 
Exit and Commit changes
QUIT 
Exit and Roll back changes

SET Options

There are several options that influence the behaviour of ISQL (this list can be retrieved by calling HELP SET;)

SET
Display current SET options
SET AUTOddl
Toggle autocommit of DDL statements
SET BAIL
Toggle bailing out on errors in non-interactive mode
SET BLOB [ALL|<n>]
Display BLOBS of subtype <n> or ALL
SET BLOB
Turn off BLOB display
SET COUNT
Toggle count of selected rows on/off
SET ECHO
Toggle command echo on/off
SET HEADING
Toggle display of query column titles
SET LIST
Toggle column or table display format
SET NAMES <csname>
Set name of runtime character set
SET PLAN
Toggle display of query access plan
SET PLANONLY
Toggle display of query plan without executing
SET SQL DIALECT <n>
Set SQL Dialect to <n>
SET STATs
Toggle display of performance statistics
SET TIME
Toggle display of timestamp with DATE values
SET TERM <string>
Change statement terminator string
SET WIDTH <col> [<n>]
Set/unset print width to <n> for column <col>

By just calling SET without parameters you can get a list of all settings.

SET TERM

SET TERM is special in that it changes the statement termination character. The default statement termination character is a semi-colon. However, if you want to create or alter a Stored Procedure or Trigger, the semi-colons contained in the body would also terminate the command that define the procedure. So to define a stored procedure:

  • Use SET TERM to change the statement termination to something that does not occur in your procedure
  • Create or alter your Stored Procedure or Trigger
  • Terminate this command with the new termination character
  • Change the termination character back to a semi-colon using SET TERM

Example

SQL> set term ^ ;
SQL> create procedure Mul (a integer, b integer)
CON> returns (Result integer)
CON> as begin
CON> Result = a * b;
CON> suspend;
CON> end ^
SQL> set term ; ^

Note that the end statement of the procedure is terminated with a caron (^) instead of a semi-colon (;). The caron has been defined as the new termination character by the first SET TERM statement.

Running SQL Scripts

You can run an SQL script by using the -i command line option. To further suppress the "Use CONNECT or CREATE DATABASE to specify a database" message that appears everytime when ISQL starts, use the -q option.

C:ProgrammeFirebird2bin>isql -q -i c:ScriptsCreateScript.sql

C:ProgrammeFirebird2bin>

In this case, the script must contain a CONNECT or CREATE DATABASE command.

Scripts should also use SET NAMES to define the Client Character Set they use.

quinta-feira, 22 de fevereiro de 2007

GFIX - Firebird Administration

GFIX is Firebird's command line tool for administration issues like data repair, sweeping, etc.

General Syntax

gfix [options] -user <username> -password <password> <database> [options]

Database Shutdown

When a database has been shut down, only SYSDBA and the database owner are able to connect to the database in order to perform administrative tasks.

Options

-at[tach] <seconds>
Used with the -shut option. Waits <seconds> seconds for all current connections to end. If after <seconds> seconds there are still connections open, the shutdown will be cancelled and return an error.
-f[orce] <seconds>
Used with the -shut option. Waits <seconds> seconds for all connections and transactions to end. After this time, all connections and transactions are cancelled and the database is shut down. Use with caution.
-o[nline]
If a -shut operation is pending, it is cancelled. Otherwise, takes a database back online
-sh[ut]
Shut down database. Must be used together with -attach, -force or -tran
-shut {normal | multi |
single | full}
Firebird 2.0 and later: New shutdown modes

NORMAL: Database is active and online
MULTI: Only connection from SYSDBA and the Database Owner will be allowed (compatible mode with Firebird 1.0/1.5)
SINGLE: Only one SYSDBA connection will be allowed
FULL: Exclusive shutdown: Database is completely offline, no connections will be allowed (it is now possible to access the database file safely on a file basis, e.g. for backups)

-tr[an] <seconds>
Used with the -shut option. Waits <seconds> seconds for all running transactions to end. If after <seconds> seconds there are still running transactions, the shutdown will be cancelled.

Examples

Shut down database, wait 60 seconds until all connections are closed

gfix -user SYSDBA -password "masterkey" dbserver:/db/mydb.fdb -shut -attach 60

Note that GFIX will terminate with an error if there are still connections open after 60 seconds.

Shut down database, force shutdown after 60 seconds

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -shut -force 60

Shut down database, force shutdown NOW

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -shut -force 0

Put database online again

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -online

Shut down database to single user mode (Firebird 2.0)

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -shut single -force 60

Put database online again (Firebird 2.0)

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -shut normal

Shut down database, force shutdown NOW, allow no subsequent connections, even from SYSDBA or Owner (Firebird 2.0)

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -shut full -force 0

Database Repair, Sweeping

Options

-f[ull]
Use with the -v option. Checks all records and pages and releases unassigned record fragments
-h[ousekeeping] 0
Switch off automatic sweeping
-h[ousekeeping] <n>
Set Sweep Interval to <n> transactions (default is 20000)
-i[gnore]
Ignores checksum errors during a validate or sweep
-m[end]
Marks corrupt records as unavailable so they are skipped on a subsequent backup
-n[o_update]
Use with the -v option. Checks all records and pages and reports errors but does not repair them
-s[weep]
Forces an immediate sweep
-v[alidate]
Check database for validity. At the same time, errors are reported and repaired

Examples

Validate Database

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -v -f

Sweep Database now

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -s

Set Sweep Interval to 50000 transactions

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -h 50000

Switch off Automatic Sweeping

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -h 0

Misc

Options

-b[uffers] <pages>
Default cache buffers for the database will be set to <pages> pages
-c[ommit] <id>
Commits limbo transaction specified by the given <id>
-c[ommit] all
Commits all limbo transactions
-l[ist]
Display IDs of all limbo transactions and what would happen to each transaction if you would use -t on it
-mo[de] read_write
Set mode of database to read/write (default). Requires exclusive access to database (shutdown)
-mo[de] read_only
Set mode of database to read-only. Requires exclusive access to database (shutdown)
-pa[ssword] <password>
Database password
-p[rompt]
Use with -l. Prompts for action.
-r[ollback] <id>
Rolls back limbo transaction specified by the given <id>
-r[ollback] all
Rolls back all limbo transactions
-s[ql_dialect] 1
Sets SQL dialect 1 for the database
-s[ql_dialect] 3
Sets SQL dialect 3 for the database
-t[wo_phase] <id>
Performs automated two-phase recovery for limbo transaction with the given <id>
-t[wo_phase] all
Performs automated two-phase recovery for all limbo transactions
-user <name>
Database username
-w[rite] sync
Enables Forced Writes
-w[rite] async
Disabled Forced Writes
-z
Show GFIX and server version

Examples

Set Database to Read-Only

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -shut -attach 60
gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -shut -force 0
gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -mode read_only
gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -online

Set Database to SQL Dialect 3

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -sql_dialect 3

Enable Forced Writes

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -write sync

Disable Forced Writes

gfix -user SYSDBA -password masterkey dbserver:/db/mydb.fdb -write async

GSEC - Firebird User Administration


GSEC is Firebird's command line tool for user administration issues.

All database users are stored in the security database named isc4.gdb (Firebird 1.0), security.fdb (Firebird 1.5) or security2.fdb (Firebird 2.0) in the Firebird directory. There is always at least one user, the system database administrator, SYSDBA.


After installation, the SYSDBA password is "masterkey". (Exception: Firebird 1.5 for Linux)

Only the first 8 characters of a password are significant. The password should not contain space characters.

Invoking GSEC

GSEC can only be run by the SYSDBA.

To use GSEC for the local machine, use:

gsec -user sysdba -password <password> [options]

To use GSEC for a remote machine, use:


gsec -user sysdba -password <password> -database <databasename>

where <databasename> is the database name of the remote security.fdb or security2.fdb database.

You can use GSEC has an interactive command line tool or give all commands on one command line.

Commands

di[splay]
Displays all users
di[splay] <username>
Displays all information for the given user
a[dd] <username> -pw <password> [options]
Add a new user
mo[dify] <username> [options]
Modify user
de[lete] <username>
Delete user
h[elp]
Display help
?
Display help
q[uit]
Quit interactive mode
z
Display GSEC version number

Wenn you don't want to invoke the interactive mode, you can give all commands directly in the command line. To do that, precede the commands with a dash.

Options

-pa[ssword] <password>
Password of the user who is performing the change
-user <username>
User name of the user who is performing the change
-pw <password>
Password of target user (or new password)
-fname <first name>
Target user's first name
-mname <middle name>
Target user's middle name
-lname <last name>
Target user's last name

Examples

Add user Elvis Presley as user ELVIS, password is "Aaron"

gsec -user SYSDBA -password masterkey

GSEC> add elvis -pw Aaron -fname Elvis -lname Presley

GSEC> quit

Change password of user ELVIS to "chuck"

gsec -user SYSDBA -password masterkey

GSEC> modify elvis -pw chuck

GSEC> quit

Change password of SYSDBA from "masterkey" to "MyKey37"

gsec -user SYSDBA -password masterkey -modify sysdba -pw MyKey37

Change password of SYSDBA to "hamburg" on remote Linux server "harry"

gsec -user SYSDBA -password masterkey -database harry:/opt/firebird/security.fdb -modify sysdba -pw hamburg

Change password of SYSDBA on remote Windows server "sally" to "hannover"

gsec -user SYSDBA -password masterkey -database sally:"C:Program FilesFirebirdsecurity.fdb" -modify sysdba -pw hannover

Change password of SYSDBA on remote server "jake" on TCP port 3051 to "london"

gsec -user SYSDBA -password masterkey -database jake/3051:/opt/firebird/security.fdb" -modify sysdba -pw london

Delete user Joe on local server

gsec -user SYSDBA -password masterkey -delete joe

Notes

On Borland InterBase systems, the security database is named isc4.gdb.
There will be a warning when a new password is longer than 8 characters.


GBAK - Firebird Backup and Restore

GBAK is Firebird's command line tool for online backup and restore of a complete database.

GBAK is able to perform a backup while the database is running. There is no need to shut down the database during a GBAK backup. GBAK will create a consistent snapshot of the database at the time it starts running. You will, however, notice a perfomance degradation during the backup, so it is a good idea to backup at night. As GBAK visits all pages of the database, so it will also perform a garbage collection on the database.

General Syntax

gbak <options> -user <username> -password <password> <source> <destination>

Backup

For backups, <source> is the database you want to back up, <destination> is the file name of the backup file. The usual extension for the backup file is .fbk for Firebird and .gbk for InterBase.

Only SYSDBA or the database owner can perform a backup. For multi-file databases, specify only the name of the first file as the database name.

Restore

For restores, <source> is the backup file and <destination> is the name of the database that is to be built up from the backup file. You will have to specify the -C option for restore.

General Options

-pas[sword] <password>
Database password
-role <role>
Connect as role [OBSOLETE]
-se[rvice]
<hostname>:service_mgr
Backup: Creates the backup file on the database server, using the Service Manager.
Restore: Creates the database from a backup file on the server, using the Service Manager.
-u[ser] <username>
Database user name
-v[erbose]
Verbose output of what GBAK is doing
-y <filename>
Redirect all output messages to <filename>
The file must not exist before running GBAK!
-y suppress_output
Quiet mode
-z
Show GBAK version and server version

Backup Options

-b[ackup_database]	
Back up. This switch is optional.
-co[nvert]
Converts external tables to internal tables
-e[xpand]
Creates an uncompressed backup
-fa[ctor] n
Blocking factor for tape device
-g[arbage collect]
Does not perform garbage collection (sweeping) during backup
-ig[nore]
Ignores checksum errors while backing up
-l[imbo]
Ignores limbo transactions while backing up
-m[etadata]
Only backs up metadata (schema). No table data will be stored.
-nt
Non-transportable format (use only when you know you will restore on same platform and database version)
-t[ransportable]
Creates a transportable backup (transportable between platforms and server versions)

Restore Options

-bu[ffers]
Set cache size for restored database
-c[reate_database]
Restore to a new database (the target database file MUST NOT exist)
-i[nactive]
All indexes will be restored as INACTIVE
-k[ill]
Does not create shadows that are defined in the backup
-mo[de] read_write
Restores to a read/write database (This is the default)
-mo[de] read_only
Restores to a read-only database
-n[o_validity]
Does not restore validity constraints. So you can restore data that does not meet these constraints and could not be restored otherwise.
-o[ne_at_a_time]
Restores one table at a time. You can use this to partially restore databases with corrupt table data
-p[age_size] <size>
Sets page size of new database. <size> can be one of 1024, 2048, 4096, 8192. Default is 1024.
-r[eplace_database]
Restores over an existing database. This can only be performed by SYSDBA or the owner of the database that is overwritten. Do NOT restore over a database that is in use! [Firebird 1.0, 1.5]
-rep[lace_database]
New abbreviation for the old -replace_database [Firebird 2.0]
-r[ecreate_database] o[verwrite]
[Firebird 2.0] Restores over an existing database. This can only be performed by SYSDBA or the owner of the database that is overwritten. Do NOT restore over a database that is in use!

-r is equivalent to -c. Only the "overwrite" option will restore over an existing database.

-use_[all_space]
Normally, on restore, database pages will be filled to about 80 %. With the use_all_space option, database pages will be filled to 100 %. (Useful for read-only databases which will see no more modifications.)

Examples

A "normal" Backup

gbak -v -t -user SYSDBA -password "masterkey" dbserver:/db/warehouse.fdb c:backupswarehouse.fbk

Backup with output to a logfile

del c:backupswarehouse.log
gbak -v -t -user SYSDBA -password masterkey -y c:backupswarehouse.log dbserver:/db/warehouse.fdb c:backupswarehouse.fbk

A "normal" Restore

gbak -c -v -user SYSDBA -password masterkey c:backupswarehouse.fbk dbserver:/db/warehouse2.fdb

Restore to an already existing database (Firebird 1.0, 1.5)

gbak -c -r -v -user SYSDBA -password masterkey c:backupswarehouse.fbk dbserver:/db/warehouse.fdb

Restore to an already existing database (Firebird 2.0)

gbak -r o -v -user SYSDBA -password masterkey c:backupswarehouse.fbk dbserver:/db/warehouse.fdb

Create a read-only database

gbak -c -v -mode read_only -use_all_space -user SYSDBA -password masterkey c:backupswarehouse.fbk c:fileswarehousedb.fdb

Multi-file backups

Syntax for backup

gbak [options] <database> <target file 1> <size 1> <target file 2> <size 2> ... <target file n>

NOTE: Do not specify a size for the last file. It will always be filled to take up what is left over, no matter how large.

Size can be given in bytes (8192), kilobytes (1024k), megabytes (5m), or gigabytes (2g)

Syntax for restore

gbak -c [options] <source file 1> <source file 2> ... <source file n> <database>

Restoring to a multi-file database

gbak -c [options] <source file> <db file 1> <size 1> <db file 2> <size 2> ... <db file n>

NOTE: Do not specify a size for the last database file. It can always grow unlimited to take up the rest.

Size can be given in bytes (8192), kilobytes (1024k), megabytes (5m), or gigabytes (2g)

Restoring from a multi-file backup to a multi-file database

gbak -c [options] <source file 1> <source file 2> ... <source file n> <db file 1> <size 1> <db file 2> <size 2> ... <db file n>

Backing up and Restoring the Security Database

Firebird 1.0, 1.5

You can perform a "normal" backup of the security database. The security database resides in the Firebird directory. It is named

  • ISC4.gdb in Firebird 1.0 and
  • security.fdb in Firebird 1.5.

Firebird 2.0

Firebird 2.0 does not allow normal database access to the security database. Its name is now security2.fdb

The only way to access the security database is via the Service Manager. As GBAK can also use the Service Manager (Option -se), you can run a backup using this option. However, the backup file will also be written to the server machine.

General Syntax:

gbak <options> -user <username> -password <password> -se <servername>:service_mgr <sec-db-name> <backup-filename>

Example:

gbak -v -t -user sysdba -password masterkey -se dbserver:service_mgr c:ProgrammeFirebird2security2.fdb C:BackupsSecurity2.fbk
  (in this case, Security2.fbk will be written to the C:Backups folder of dbserver)

When your database server listens on a non-default port:

gbak -v -t -user sysdba -password masterkey -se dbserver/3051:service_mgr c:ProgrammeFirebird2security2.fdb C:BackupsSecurity2.fbk

Restoring the Security Database

It is not possible to restore the security database while Firebird is running. In case your security database gets destroyed, this is what you can do:

  • Stop the Firebird service/daemon
  • Replace the current security database with a new one. If anything else fails, re-install the Firebird server
  • You should now have a working SYSDBA login and password. If not, re-install the Firebird server ...
  • Start the Firebird service/daemon
  • Using GBAK, restore your backup of the security database to a temporary place (like C:Tempsecurity.fdb)
  • Stop the Firebird service/daemon again
  • Now copy the file from the temporary place to the correct place in the Firebird folder
  • Start the Firebird service/daemon
  • Now you should have your "old" security database back.
  • Good Luck! :-)

Upgrading a Security Database to Firebird 2.0

There is a special chapter "Dealing with the New Security Database" about this in the Firebird 2.0 Release Notes, which get installed to the doc subdirectory of your Firebird directory. You should also take a look at the miscupgradesecuritysecurity_database.txt file, which explains in detail how to do it.

terça-feira, 6 de fevereiro de 2007

Códigos de erro do Winsock

Códigos de erro do Winsock

Quando Firebird em Windows tem um problema com o subsistema da rede um erro Win32 desconhecido volta com um número (como por exemplo 10060). O número é um número do erro do Winsock. Esta é uma lista de todos os números do erro do Winsock:

Error# Error Code Error Text
10004 WSAEINTR Interrupted function call
10009 WSAEBADF WSAEBADF
10013 WSAEACCES WSAEACCES
10014 WSAEFAULT Bad address
10022 WSAEINVAL Invalid argument
10024 WSAEMFILE Too many open files
10035 WSAEWOULDBLOCK Operation would block
10036 WSAEINPROGRESS Operation now in progress
10037 WSAEALREADY Operation already in progress
10038 WSAENOTSOCK Socket operation on non-socket
10039 WSAEDESTADDRREQ Destination address required
10040 WSAEMSGSIZE Message too long
10041 WSAEPROTOTYPE Protocol wrong type for socket
10042 WSAENOPROTOOPT Bad protocol option
10043 WSAEPROTONOSUPPORT Protocol not supported
10044 WSAESOCKTNOSUPPORT Socket type not supported
10045 WSAEOPNOTSUPP Operation not supported
10046 WSAEPFNOSUPPORT Protocol family not supported
10047 WSAEAFNOSUPPORT Address family not supported by protocol family
10048 WSAEADDRINUSE Address already in use
10049 WSAEADDRNOTAVAIL Cannot assign requested address
10050 WSAENETDOWN Network is down
10051 WSAENETUNREACH Network is unreachable
10052 WSAENETRESET Network dropped connection on reset
10053 WSAECONNABORTED Software caused connection abort
10054 WSAECONNRESET Connection reset by peer
10055 WSAENOBUFS No buffer space available
10056 WSAEISCONN Socket is already connected
10057 WSAENOTCONN Socket is not connected
10058 WSAESHUTDOWN Cannot send after socket shutdown
10059 WSAETOOMANYREFS WSAETOOMANYREFS
10060 WSAETIMEDOUT Connection timed out
10061 WSAECONNREFUSED Connection refused
10062 WSAELOOP WSAELOOP
10063 WSAENAMETOOLONG WSAENAMETOOLONG
10064 WSAEHOSTDOWN Host is down
10065 WSAEHOSTUNREACH No route to host
10066 WSAENOTEMPTY WSAENOTEMPTY
10067 WSAEPROCLIM Too many processes
10068 WSAEUSERS WSAEUSERS
10069 WSAEDQUOT WSAEDQUOT
10070 WSAESTALE WSAESTALE
10071 WSAEREMOTE WSAEREMOTE
10091 WSASYSNOTREADY Network subsystem is unavailable
10092 WSAVERNOTSUPPORTED WINSOCK.DLL version out of range
10093 WSANOTINITIALISED Successful WSAStartup() not yet performed
10101 WSAEDISCON WSAEDISCON
10102 WSAENOMORE WSAENOMORE
10103 WSAECANCELLED WSAECANCELLED
10104 WSAEINVALIDPROCTABLE WSAEINVALIDPROCTABLE
10105 WSAEINVALIDPROVIDER WSAEINVALIDPROVIDER
10106 WSAEPROVIDERFAILEDINIT WSAEPROVIDERFAILEDINIT
10107 WSASYSCALLFAILURE WSASYSCALLFAILURE
10108 WSASERVICE_NOT_FOUND WSASERVICE_NOT_FOUND
10109 WSATYPE_NOT_FOUND WSATYPE_NOT_FOUND
10110 WSA_E_NO_MORE WSA_E_NO_MORE
10111 WSA_E_CANCELLED WSA_E_CANCELLED
10112 WSAEREFUSED WSAEREFUSED
11001 WSAHOST_NOT_FOUND Host not found
11002 WSATRY_AGAIN Non-authoritative host not found
11003 WSANO_RECOVERY This is a non-recoverable error
11004 WSANO_DATA Valid name, no data record of requested type


Neobux