-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathLivro.pas
178 lines (161 loc) · 5.81 KB
/
Livro.pas
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
unit Livro;
interface
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Vcl.ExtCtrls, uADStanIntf,
uADStanOption, uADStanParam, uADStanError, uADDatSManager, uADPhysIntf,
uADDAptIntf, uADStanAsync, uADDAptManager, Data.DB, uADCompDataSet,
uADCompClient, Vcl.Grids, Vcl.DBGrids;
type
TfrmCadLivro = class(TForm)
editTitulo: TLabeledEdit;
editAutor: TLabeledEdit;
editDescricao: TLabeledEdit;
comboEditora: TComboBox;
editValor: TLabeledEdit;
editAno: TLabeledEdit;
Label1: TLabel;
btnSalvar: TButton;
btnExcluir: TButton;
btnAtualizar: TButton;
btnCancelar: TButton;
ADQuery1: TADQuery;
DataSource1: TDataSource;
dbGridLivros: TDBGrid;
editID: TLabeledEdit;
btnListar: TButton;
procedure btnSalvarClick(Sender: TObject);
procedure FormShow(Sender: TObject);
procedure btnAtualizarClick(Sender: TObject);
procedure dbGridLivrosCellClick(Column: TColumn);
procedure btnExcluirClick(Sender: TObject);
procedure btnCancelarClick(Sender: TObject);
procedure btnListarClick(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
end;
var
frmCadLivro: TfrmCadLivro;
implementation
{$R *.dfm}
//cadastra livro
procedure TfrmCadLivro.btnSalvarClick(Sender: TObject);
begin
if editID.Text <> '' then begin
ShowMessage('O campo ID deve estar em branco para realizar um novo cadastro!');
exit;
end;
if editTitulo.Text <> '' then begin
ADQuery1.Close;
ADQuery1.SQL.Clear;
ADQuery1.SQL.Add('INSERT INTO TBLIVRO (TITULO, DESCRICAO, ID_EDITORA, AUTOR, ANO, VALOR, ID_USUARIO) VALUES (:TITULO, :DESCRICAO, :ID_EDITORA, :AUTOR, :ANO, :VALOR, 1)');
ADQuery1.ParamByName('TITULO').AsString := editTitulo.Text;
ADQuery1.ParamByName('DESCRICAO').AsString := editDescricao.Text;
ADQuery1.ParamByName('ID_EDITORA').AsInteger := StrToIntDef(comboEditora.Text, 0);
ADQuery1.ParamByName('AUTOR').AsString := editAutor.Text;
ADQuery1.ParamByName('ANO').AsInteger := StrToIntDef(editAno.Text, 0);
ADQuery1.ParamByName('VALOR').AsCurrency := StrToCurrDef(editAno.Text, 0);
ADQuery1.ExecSQL;
btnListarClick(Sender);
end;
end;
//lista itens na grid após clicar no botão Listar
procedure TfrmCadLivro.btnListarClick(Sender: TObject);
begin
ADQuery1.Close;
ADQuery1.SQL.Clear;
ADQuery1.SQL.Add('SELECT * FROM TBLIVRO');
ADQuery1.Open;
end;
//insere os dados da linha que foi clicada no DBgrid
procedure TfrmCadLivro.dbGridLivrosCellClick(Column: TColumn);
begin
editID.Text := dbGridLivros.DataSource.DataSet.FieldByName('ID').AsString;
editTitulo.Text := dbGridLivros.DataSource.DataSet.FieldByName('TITULO').AsString;
editDescricao.Text := dbGridLivros.DataSource.DataSet.FieldByName('DESCRICAO').AsString;
comboEditora.Text := dbGridLivros.DataSource.DataSet.FieldByName('ID_EDITORA').AsString;
editAutor.Text := dbGridLivros.DataSource.DataSet.FieldByName('AUTOR').AsString;
editAno.Text := dbGridLivros.DataSource.DataSet.FieldByName('ANO').AsString;
editValor.Text := dbGridLivros.DataSource.DataSet.FieldByName('VALOR').AsString;
end;
//carrega os dados da DBgrid após mostrar o formulário
procedure TfrmCadLivro.FormShow(Sender: TObject);
begin
ADQuery1.Close;
ADQuery1.SQL.Clear;
ADQuery1.SQL.Add('SELECT * FROM TBLIVRO');
ADQuery1.Open;
end;
//atualiza dados
procedure TfrmCadLivro.btnAtualizarClick(Sender: TObject);
begin
if editID.Text <> '' then begin //verifica id e descrição se estão vazios
ADQuery1.Close;
ADQuery1.SQL.Clear;
ADQuery1.SQL.Add('SELECT ID FROM TBLIVRO WHERE ID = :ID');
ADQuery1.ParamByName('ID').AsString := editID.Text;
ADQuery1.Open;
if not ADQuery1.IsEmpty then begin
try
ADQuery1.Close;
ADQuery1.SQL.Clear;
ADQuery1.SQL.Add('UPDATE TBLIVRO SET TITULO = :TITULO, DESCRICAO = :DESCRICAO, ID_EDITORA = :EDITORA, AUTOR = :AUTOR, ANO = :ANO, VALOR = :VALOR WHERE ID = :ID');
ADQuery1.ParamByName('TITULO').AsString := editTitulo.Text;
ADQuery1.ParamByName('DESCRICAO').AsString := editDescricao.Text;
ADQuery1.ParamByName('EDITORA').AsInteger := StrToIntDef(comboEditora.Text, 0);
ADQuery1.ParamByName('AUTOR').AsString := editAutor.Text;
ADQuery1.ParamByName('ANO').AsInteger := StrToIntDef(editAno.Text, 0);
ADQuery1.ParamByName('VALOR').AsCurrency := StrToCurrDef(editAno.Text, 0);
ADQuery1.ParamByName('ID').AsString := editID.Text;
ADQuery1.ExecSQL;
finally
btnListarClick(Sender);
ShowMessage('Atualizado com sucesso!');
end;
end;
end;
end;
//excluir livro
procedure TfrmCadLivro.btnExcluirClick(Sender: TObject);
begin
if editID.Text <> '' then begin //verifica id e descrição se estão vazios
ADQuery1.Close;
ADQuery1.SQL.Clear;
ADQuery1.SQL.Add('SELECT ID FROM TBLIVRO WHERE ID = :ID');
ADQuery1.ParamByName('ID').AsString := editID.Text;
ADQuery1.Open;
if not ADQuery1.IsEmpty then begin
try
ADQuery1.Close;
ADQuery1.SQL.Clear;
ADQuery1.SQL.Add('DELETE FROM TBLIVRO WHERE ID = :ID');
ADQuery1.ParamByName('ID').AsString := editID.Text;
ADQuery1.ExecSQL;
finally
editID.Clear;
editTitulo.Clear;
comboEditora.Clear;
editDescricao.Clear;
editAutor.Clear;
editAno.Clear;
editValor.Clear;
btnListarClick(Sender);
ShowMessage('Deletado com sucesso!');
end;
end;
end;
end;
//cancelar
procedure TfrmCadLivro.btnCancelarClick(Sender: TObject);
begin
editID.Clear;
editTitulo.Clear;
comboEditora.Clear;
editDescricao.Clear;
editAutor.Clear;
editAno.Clear;
editValor.Clear;
end;
end.