[RESOLVIDO]Problemas com JDateCHooser

6 respostas
E

Boa tarde.

Estou enfrentando problemas com o JDateChooser, estou até conseguir pegar o valor no banco e exibir data no componente no formato que eu quero > “dd/MM/yyyy”.
O problema é pegar o valor do JDateChooser, alterando ele, e enviando para o banco, no código abaixo eu consigo alterá-lo do formato “Mon Jun 20 00:00:00 BRT 1921” para o formato “1921-06-20”, porém no meu banco Firebird já está com o formato Date “20-06-1921” e não posso alterar o banco.

Parece que a msg de erro que é exibida é devido ao fato de tentar inserir Date “1921-06-20” no banco que está como Date “20-06-1921”, mas não consigo mudar.
O que estou fazendo errado ?

SimpleDateFormat df = new SimpleDateFormat(dd/MM/yyyy);

JOptionPane.showMessageDialog(null, "antes de mudar o formato  " + dcDataNasc.getDate());

java.sql.Date d = null;

try {

d = new java.sql.Date(df.parse(df.format(dcDataNasc.getDate())).getTime());
} catch (ParseException e) {  
                JOptionPane.showMessageDialog(rootPane,"Introduza a data correcta", "ERRO",JOptionPane.ERROR_MESSAGE);  
            }                      
    novaPessoa.setPe_dtnasc(d);        
    JOptionPane.showMessageDialog(null, "depois de mudar tá assim >>.   " + d);

MENSAGEM DE ERRO:

Exception in thread “AWT-EventQueue-0” java.lang.IllegalArgumentException
at java.sql.Date.valueOf(Date.java:138)

6 Respostas

asandrob

Tchê, testei o teu código e funcionou!!!
Considerei que dcDataNasc é da biblioteca JCalendar.
dá um System.out.println(d); depois desta linha d = new java.sql.Date(df.parse(df.format(dcDataNasc.getDate())).getTime());
Aqui imprimiu 2012-07-06, o que eu escolhi no DateChooser

Será que o erro é neste trecho? Manda todo o stacktrace…

E

Então, na vdd eu quero que imprima nesse formato: 06-07-2012

Mas só sai nesse 2012-07-06 o que impede que eu faça a inserção no banco, pois no banco está no formato Date (06-07-2012) ou seja dd-MM-yyyy.

Não estou no meu pc, depois mando o stacktrace completo

E
Exception in thread AWT-EventQueue-0 java.lang.IllegalArgumentException

at java.sql.Date.valueOf(Date.java:138)

at org.firebirdsql.jdbc.field.FBDateField.setString(FBDateField.java:78)

at org.firebirdsql.jdbc.field.FBField.setObject(FBField.java:733)

at org.firebirdsql.jdbc.AbstractPreparedStatement.setObject(AbstractPreparedStatement.java:218)

at br.com.cras.banco.GenericoDAO.executeCommand(GenericoDAO.java:99)

at br.com.cras.banco.PessoaDAO.alterarPessoa(PessoaDAO.java:69)

at br.com.cras.telas.frmCadastroFamilia.jButtonAlterarActionPerformed(frmCadastroFamilia.java:865)

at br.com.cras.telas.frmCadastroFamilia.access$1000(frmCadastroFamilia.java:24)

at br.com.cras.telas.frmCadastroFamilia$11.actionPerformed(frmCadastroFamilia.java:616)

at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1995)

at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2318)

at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:387)

at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:242)

at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:236)

at java.awt.Component.processMouseEvent(Component.java:6289)

at javax.swing.JComponent.processMouseEvent(JComponent.java:3267)

at java.awt.Component.processEvent(Component.java:6054)

at java.awt.Container.processEvent(Container.java:2041)

at java.awt.Component.dispatchEventImpl(Component.java:4652)

at java.awt.Container.dispatchEventImpl(Container.java:2099)

at java.awt.Component.dispatchEvent(Component.java:4482)

at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4577)

at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4238)

at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4168)

at java.awt.Container.dispatchEventImpl(Container.java:2085)

at java.awt.Window.dispatchEventImpl(Window.java:2478)

at java.awt.Component.dispatchEvent(Component.java:4482)

at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:644)

at java.awt.EventQueue.access$000(EventQueue.java:85)

at java.awt.EventQueue$1.run(EventQueue.java:603)

at java.awt.EventQueue$1.run(EventQueue.java:601)

at java.security.AccessController.doPrivileged(Native Method)

at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:87)

at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:98)

at java.awt.EventQueue$2.run(EventQueue.java:617)

at java.awt.EventQueue$2.run(EventQueue.java:615)

at java.security.AccessController.doPrivileged(Native Method)

at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:87)

at java.awt.EventQueue.dispatchEvent(EventQueue.java:614)

at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:269)

at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:184)

at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:174)

at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:169)

at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:161)

at java.awt.EventDispatchThread.run(EventDispatchThread.java:122)

CONSTRUÇÃO PARADA (tempo total: 45 segundos)

LEMBRANDO QUE NO BANCO (FIREBIRD) O FORMATO ESTÁ “01/11/2000” E NÃO “200/11/01”.

Não sei pq altero o formato da data no código java via SimpleDateFormat conforme o código que mandei, mas o resultado continua sendo no formato invertido.

pmlm

Um Date é uma data, não tem formato. O que tem formato é a String que representa a data e que é mostrada para os utilizadores da aplicação.

Para a BD só tens de enviar o Date sem te preocupares com o formato.

Date d = dcDataNasc.getDate();
...
statement.setDate(new java.sql.Date(d.getTime());
...
R

Devo estar seguindo o mesmo tutorial.
Completando o código, eu tb estou com problemas, mas além da classe citada, tenho as classes PessoaDAO e Pessoa e a classe CadastroFam que completa o MVC.

import java.util.Date;

public class Pessoa implements Serializable{

@ColunaTabela(description = Codigo, renderer=DefaultTableCellRenderer.class, coloOfBackgound="")

private Integer pe_cod;

private Date pe_dtnasc;

…getters e setters…etc

public class PessoaDAO extends ConexaoDAO {

public static Pessoa pessoa;

public static PreparedStatement sta;

public static ResultSet res;

private static SimpleDateFormat formatter;
public void alterarPessoa(Pessoa pessoa) throws SQLException {
     String query = "update pessoa  set  pe_dtnasc = ?where pe_cod = ?;" ;
     executeCommand(query, pessoa.getPe_cod(),
                          pessoa.getPe_dtnasc(),
                          ....                }
import java.util.Date;

public class CadastroFam extends javax.swing.JFrame {

public static PessoaDAO dao = new PessoaDAO();

public static Pessoa umaPessoa = new Pessoa();

private void jButtonAlterarActionPerformed(java.awt.event.ActionEvent evt) {
//crio d(date) e recebo a informação contida no JDateCHooser(dcDataNasc)
           Date d = dcDataNasc.getDate(); 
           //tento inserir atraves do metodo setPe_dtnasc() a data, mas não consigo inserir no banco dessa maneira, nem com o código que foi postado pelo outro usuario do forum
           umaPessoa.setPe_dtnasc(new java.sql.Date(d.getTime()));

Poderia usar como foi passado: statement.setDate(new java.sql.Date(d.getTime());
Mas estou usando MVC para acesso ao banco e depois exibir na tela, já tentei usar DateFormat e outros.

Exception in thread AWT-EventQueue-0 java.lang.IllegalArgumentException

at java.sql.Date.valueOf(Date.java:138)

at org.firebirdsql.jdbc.field.FBDateField.setString(FBDateField.java:78)
E

Agora sim, realmente não precisava de nenhuma formatação.

Criado 6 de julho de 2012
Ultima resposta 24 de jul. de 2012
Respostas 6
Participantes 4