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