![]() |
|
||||
![]() Diga adeus às planilhas do Excel e tenha 100% de controle sobre suas contas a pagar e a receber, gestão de receitas e despesas, cadastro de clientes e fornecedores com fotos e histórico de atendimentos. Código fonte completo e funcional, com instruções para instalação e configuração do banco de dados MySQL. Fácil de modificar e adicionar novas funcionalidades. Clique aqui e saiba mais |
Você está aqui: Delphi ::: dbExpress ::: TSQLConnection |
||||||||||||
Usando a propriedade Connected ou o método Open() da classe TSQLConnection para estabelecer uma conexão com um banco de dadosQuantidade de visualizações: 4649 vezes |
||||||||||||
Uma dúvida frequente entre desenvolvedores Delphi + dbExpress é a diferença entre a propriedade Connected e o método Open() da classe TSQLConnection. Ambos são usados para abrir a conexão com o servidor de banco de dados. Quando definimos o valor True para a propriedade Connected, automaticamente uma conexão com o banco de dados será feita. Antes que a conexão seja estabelecida, um evento BeforeConnect é disparado. Após a conexão ser estabelecida, o evento AfterConnect é disparado. Veja um trecho de código no qual usamos o evento Click de um botão para atribuir o valor True para a propriedade Connected de um TSQLConnection e assim abrir a conexão com o banco de dados:
O mesmo resultado é alcançado usando o método Open(). Veja:
Tudo que o método ou procedure Open() faz é ajustar o valor da propriedade Connected para True. É possível também usar a propriedade Connected para verificar se a conexão com o banco de dados está ativa. Veja:
|
||||||||||||
![]() |
||||||||||||
Delphi ::: Data Access Controls (Controles de Acesso a Dados) ::: TClientDataSet |
||||||||
Como tornar o TClientDataSet do Delphi somente leitura usando a propriedade ReadOnlyQuantidade de visualizações: 11651 vezes |
||||||||
Em algumas situações gostaríamos que um TClientDataSet fosse somente leitura, ou seja, não queremos permitir inserção, atualização ou exclusão dos dados do dataset. Para isso podemos usar a propriedade ReadOnly. Se seu valor for True, os dados do TClientDataSet serão apenas para leitura. Se o valor for False, os dados podem ser modificados e/ou novos dados podem ser inseridos no dataset. O valor padrão é False. Em tempo de design a propriedade ReadOnly do TClientDataSet pode ser ajustada selecionando-se o componente no formulário e acessando o Object Inspector. Em tempo de execução esta propriedade pode ser ajustada por meio do seguinte trecho de código:
Se necessário, podemos obter o valor desta propriedade em tempo de execução da seguinte forma:
Ao executarmos este código e clicarmos no botão teremos uma mensagem parecida com: "O ClientDataSet NÃO é somente leitura". É importante observar que se tentarmos efetuar alguma operação que modifica o conteúdo de um TClientDataSet somente leitura nós teremos uma exceção do tipo: Project Project2.exe raised exception class EDatabaseError with message 'ClientDataSet1': Cannot modify a read-only dataset'. Quando ajustamos o valor da propriedade ReadOnly para True, automaticamente a propriedade CanModify do dataset é ajustada para False. Importante: Mesmo que o valor da propriedade ReadOnly seja False, os usuários ainda podem ser impedidos de modificar os dados de um client dataset se este obtém seus dados a partir de um provider (por exemplo: TDataSetProvider). A propriedade Options do provider pode limitar se os dados podem ser editados e, se puderem, os tipos de alterações permitidos. Esta dica foi escrita e testada no Delphi 2009. | ||||||||
Delphi ::: Dicas & Truques ::: Imagens e Processamento de Imagens |
||||
Como capturar um screenshot da área de trabalho e salvá-lo como um Bitmap usando DelphiQuantidade de visualizações: 13604 vezes |
||||
Em algumas situações precisamos capturar um screenshot da área de trabalho (Windows Desktop) e salvá-lo como um Bitmap. Esta dica mostra como isso pode ser feito. Note que aqui estamos salvando o bitmap gerado no mesmo diretório do executável. Caso queira salvar o resultado em outra pasta ou diretório, consulte minhas dicas sobre a manipulação de arquivos e diretórios usando Delphi. Veja o código (coloquei no evento OnClick de um botão:
Para fins de compatibilidade, esta dica foi escrita usando Delphi 2009. | ||||
Delphi ::: VCL - Visual Component Library ::: TListBox |
||||||||||||||||
Como usar a propriedade Items da classe TListBox do DelphiQuantidade de visualizações: 11362 vezes |
||||||||||||||||
A propriedade Items da classe TListBox representa um objeto da classe TStrings, a classe base para objetos que representam uma lista de strings. Isso quer dizer que podemos acessar a propriedade Items e usar todos os métodos e propriedades da classe TStrings, tais como Add(), Clear(), Delete(), Exchange(), etc. Veja, por exemplo, como usar o método Add() para adicionar um novo item na ListBox:
É possível obter um referência à propriedade Items para manipular os itens da ListBox indiretamente. Veja:
Esta técnica é útil quando queremos inserir itens em uma TListBox a partir de uma função ou procedure. Veja:
Para finalizar, veja como escrever uma função personalizada que constrói e retorna uma lista de strings. Note como usamos o objeto TStrings retornado para preencher a ListBox:
Observe que, embora o retorno seja TStrings, no corpo da função nós construímos um objeto da classe TStringList. Isso acontece porque TStrings é uma classe abstrata e, portanto, não podemos chamar seu construtor. Como TStringList herda de TStrings e é uma classe concreta, esta é a escolha mais óbvia. Para fins de compatibilidade, esta dica foi escrita usando Delphi 2009. | ||||||||||||||||
Desafios, Exercícios e Algoritmos Resolvidos de Delphi |
Veja mais Dicas e truques de Delphi |
Dicas e truques de outras linguagens |
E-Books em PDF |
||||
|
||||
|
||||
Linguagens Mais Populares |
||||
1º lugar: Java |