Lazarus
Home
Help
TinyPortal
Search
Login
Register
Lazarus
»
Forum
»
Programming
»
Databases
»
Firebird Create Table (SOLVED)
Free Pascal
Website
Downloads
Wiki
Documentation
Bugtracker
Mailing List
Lazarus
Website
Downloads (Laz+FPC)
Packages (OPM)
FAQ
Wiki
Documentation (RTL/FCL/LCL)
Bugtracker
CCR Bugs
IRC channel
GIT
Mailing List
Other languages
Foundation
Website
Useful Wiki Links
Project Roadmap
Getting the Source
Screenshots
How to use the forum
About donations (wiki)
Bookstore
Computer Math and Games in Pascal
(preview)
Lazarus Handbook
Search
Advanced search
Recent
Does anyone know why thes...
by
TYDQ
[
Today
at 05:24:32 am]
Forum slow
by
Curt Carpenter
[
Today
at 03:41:07 am]
Arabic text, problem on L...
by
Zaher
[
Today
at 03:29:16 am]
InstallAware Using Lazaru...
by
TRon
[
Today
at 02:55:41 am]
Generics - correct syntax
by
Blaazen
[
Today
at 01:57:40 am]
Demoscene The Champs Crac...
by
Gigatron
[
Today
at 01:05:16 am]
How to use the Event Log?
by
n7800
[
Today
at 12:47:25 am]
v3.99 code completion que...
by
440bx
[
Today
at 12:45:55 am]
FpDebug breakpoint on "be...
by
440bx
[
Today
at 12:36:23 am]
Access violation when re-...
by
TRon
[April 19, 2024, 11:44:51 pm]
[solved] how to get class...
by
jamie
[April 19, 2024, 11:34:44 pm]
Lazarus for Windows on aa...
by
Wallaby
[April 19, 2024, 10:52:25 pm]
Poll: Watches and Display...
by
440bx
[April 19, 2024, 07:13:51 pm]
Who is Indy mattias?
by
paweld
[April 19, 2024, 04:17:53 pm]
I just released a commerc...
by
BrassGear
[April 19, 2024, 03:17:28 pm]
Database standards OR Am ...
by
gidesa
[April 19, 2024, 02:37:56 pm]
How to: create DLL file f...
by
TRon
[April 19, 2024, 02:26:53 pm]
A fairly simple sound sol...
by
paweld
[April 19, 2024, 01:46:11 pm]
Access violation when ope...
by
Чебурашка
[April 19, 2024, 12:27:34 pm]
Step-into the field sette...
by
Martin_fr
[April 19, 2024, 11:31:48 am]
AI, NLP and CAI: Text Gen...
by
Dzandaa
[April 19, 2024, 11:03:26 am]
dwindows for Android
by
PierceNg
[April 19, 2024, 10:54:44 am]
create system unit from s...
by
Laksen
[April 19, 2024, 10:53:57 am]
[Solved] Find child contr...
by
Joanna
[April 19, 2024, 09:53:43 am]
FpDebug unexpected Assemb...
by
Marc
[April 19, 2024, 08:46:38 am]
« previous
next »
Print
Pages: [
1
]
Author
Topic: Firebird Create Table (SOLVED) (Read 2380 times)
TheLastCayen
Jr. Member
Posts: 81
Firebird Create Table (SOLVED)
«
on:
November 10, 2019, 01:04:11 am »
Hi
I am using:
- Lazarus 2.0.6
- FPC 3.0.4
How do you create a table in your code using firebird? The wiki recommends using the tool from lazarus but I want my code to do it.
This is my code so far:
Code: Pascal
[Select]
[+]
[-]
unit
Unit1
;
{$mode objfpc}{$H+}
interface
uses
Classes
,
SysUtils
,
IBConnection
,
sqldb
,
db
,
Forms
,
Controls
,
Graphics
,
Dialogs
,
StdCtrls
;
type
{ TForm1 }
TForm1
=
class
(
TForm
)
Button1
:
TButton
;
Button2
:
TButton
;
procedure
Button1Click
(
Sender
:
TObject
)
;
procedure
Button2Click
(
Sender
:
TObject
)
;
procedure
FormCreate
(
Sender
:
TObject
)
;
procedure
FormDestroy
(
Sender
:
TObject
)
;
procedure
CreateDB
;
private
public
end
;
var
Form1
:
TForm1
;
implementation
{$R *.lfm}
{ TForm1 }
var
DBConnection
:
TIBConnection
;
SQLTransaction
:
TSQLTransaction
;
SQLQuery
:
TSQLQuery
;
DataSource
:
TDataSource
;
procedure
TForm1
.
Button1Click
(
Sender
:
TObject
)
;
begin
CreateDB
;
end
;
procedure
TForm1
.
Button2Click
(
Sender
:
TObject
)
;
begin
if
FileExists
(
DBConnection
.
DatabaseName
)
then
DeleteFile
(
DBConnection
.
DatabaseName
)
;
end
;
procedure
TForm1
.
FormCreate
(
Sender
:
TObject
)
;
begin
DBConnection
:
=
TIBConnection
.
Create
(
nil
)
;
SQLTransaction
:
=
TSQLTransaction
.
Create
(
nil
)
;
SQLQuery
:
=
TSQLQuery
.
Create
(
nil
)
;
DataSource
:
=
TDataSource
.
Create
(
nil
)
;
With
DBConnection
do
begin
HostName
:
=
''
;
DatabaseName
:
=
'test1.fdb'
;
UserName
:
=
'SYSDBA'
;
Password
:
=
'apple'
;
Charset
:
=
'UTF8'
;
Dialect
:
=
3
;
Transaction
:
=
SQLTransaction
;
end
;
SQLQuery
.
DataBase
:
=
DBConnection
;
DataSource
.
DataSet
:
=
SQLQuery
;
end
;
procedure
TForm1
.
FormDestroy
(
Sender
:
TObject
)
;
begin
DataSource
.
free
;
SQLQuery
.
free
;
SQLTransaction
.
free
;
DBConnection
.
free
;
end
;
procedure
TForm1
.
CreateDB
;
begin
DBConnection
.
CreateDB
;
SQLQuery
.
Close
;
SQLQuery
.
SQL
.
Text
:
=
'CREATE TABLE TEST(ID INTEGER NOT NULL, TESTNAME VARCHAR(800))'
;
DBConnection
.
Connected
:
=
True
;
SQLTransaction
.
Active
:
=
True
;
SQLQuery
.
Open
;
end
;
end
.
The procedure CreateDB returns an error because my statement is not a select. So far I only find partial answers on internet or people suggest using a tool to create your table... Does anyone know how to do it from the code?
«
Last Edit: November 10, 2019, 06:29:30 am by TheLastCayen
»
Logged
JanRoza
Hero Member
Posts: 672
Re: Firebird Create Table
«
Reply #1 on:
November 10, 2019, 01:34:10 am »
Try SQLQuery.ExecSQL instead of SQLQuery.Open.
Logged
OS: Windows 10 (64 bit) / Linux Mint (64 bit)
Lazarus 3.2 FPC 3.2.2
CodeTyphon 8.40 FPC 3.3.1
TheLastCayen
Jr. Member
Posts: 81
Re: Firebird Create Table
«
Reply #2 on:
November 10, 2019, 06:29:05 am »
Thank you JanRoza,
SQLQuery.ExecSQL; remove the error message but I also had to add: SQLTransaction.Commit;
Logged
TheLastCayen
Jr. Member
Posts: 81
Re: Firebird Create Table (SOLVED)
«
Reply #3 on:
November 10, 2019, 08:58:22 pm »
For future reference. This is my code to create a table with auto-indentation.
Code: Pascal
[Select]
[+]
[-]
procedure
TForm1
.
CreateDB
;
begin
DBConnection
.
CreateDB
;
With
SQLQuery
do
begin
SQL
.
Clear
;
SQL
.
ADD
(
'CREATE TABLE TEST(ID INTEGER NOT NULL, TESTNAME VARCHAR(800))'
)
;
ExecSQL
;
SQL
.
Clear
;
SQL
.
Add
(
'CREATE GENERATOR "gen_TEST_ID";'
)
;
ExecSQL
;
SQL
.
Clear
;
SQL
.
add
(
'SET GENERATOR "gen_TEST_ID" TO 0;'
)
;
ExecSQL
;
SQL
.
Clear
;
SQL
.
Add
(
'CREATE TRIGGER "SET_TEST_ID" FOR "TEST" ACTIVE BEFORE INSERT POSITION 0 AS'
)
;
SQL
.
Add
(
'BEGIN'
)
;
SQL
.
Add
(
' if (new.ID is null) then'
)
;
SQL
.
Add
(
' new.ID = gen_id("gen_TEST_ID", 1);'
)
;
SQL
.
Add
(
'END'
)
;
ExecSQL
;
end
;
SQLTransaction
.
Commit
;
end
;
For more robust code, SQLQuery.ExecSQL should be contained in a try. Something like this:
Code: Pascal
[Select]
[+]
[-]
try
ExecSQL
;
except
on E
:
Exception
do
raise
Exception
.
Create
(
'ERROR 4:'
+
sLineBreak
+
E
.
Message
)
;
end
;
Logged
Print
Pages: [
1
]
« previous
next »
Lazarus
»
Forum
»
Programming
»
Databases
»
Firebird Create Table (SOLVED)
TinyPortal
© 2005-2018