[RESOLVIDO]Problemas com JDateCHooser

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)

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…

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

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.

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());
...

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)

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