Последние несколько часов я чесал голову, размышляя, что не так. Я хочу отредактировать формат даты / времени в моей базе данных доступа, и это просто продолжает сбивать меня с толку, почему я не могу обновить его. Это мой код, и я объясню. , ,

Это основной класс, в котором есть кнопка с надписью update и при нажатии на нее появится другой класс с именем UpdateBooking_Run ().

public MainInterface() {
    JButton updateBookings = new JButton("UPDATE");
    updateBookings.addActionListener(new ActionListener() {
        public void actionPerformed(ActionEvent arg0) {
            UpdateBooking_Run ub = new UpdateBooking_Run();
            ub.setVisible(true);
        }
    });
 }

Это UpdateBooking_Run () без текстовых полей, только кнопка внутри этого класса ... Как видно из строки, я конвертировал дату в java.sql.Date.

public class UpdateBooking_Run extends JFrame {
   public static java.sql.Date sqldate;
   public UpdateBooking_Run() {
      JButton btnAdd = new JButton("UPDATE");
       btnAdd.addActionListener(new ActionListener() {
          public void actionPerformed(ActionEvent arg0) {
            try {
                Integer.parseInt(yearBookings.getText().trim());
            }
            catch (NumberFormatException na) {
                JOptionPane.showMessageDialog(null, "Please input year", "Error", JOptionPane.ERROR_MESSAGE);

            }

            DateFormat df = new SimpleDateFormat("yyyy/MM/dd");
            String mu = monthBookings.getSelectedItem().toString();
            String da = dayBookings.getSelectedItem().toString();
            String ye = yearBookings.getText().trim();

            String dat =  ye + "/" + mu + "/" + da ;

            java.util.Date date = null;

            try {
                date = df.parse(dat);
            } catch (ParseException e) {
                e.printStackTrace();
            }
            sqldate = new java.sql.Date(date.getTime());

            try {
                UpdateConn_Run uc = new UpdateConn_Run();
                uc.updateDate();
            }
            catch (Exception en) {
                en.printStackTrace();
            }
          }
       });
     }
  }

Как вы можете видеть из приведенного выше кода, я установил sqldate как статический в основном потому, что он работал с обновлением строки в других моих классах, но я просто не могу обновить Date. , ,

Тогда это соединение ... Или UpdateConn_Run ()

public class UpdateConn_Run {
   Connection con;
   Statement st;
   ResultSet rs;
   StringBuffer results;
   String url = "jdbc:ucanaccess://C://DATABASE//DATA.accdb";   
   PreparedStatement ps;

      public void updateBooking() {
        try {
           int i = 1;
           UpdateBooking_Run ubr = new UpdateBooking_Run();
           MainInterface mi = new MainInterface();

        Date da = UpdateBooking_Run.sqldate;

        con = DriverManager.getConnection(url);
        //theres actually an uneditable textbox in MainInterface that shows the ID of the selected row
        int id = Integer.parseInt(mi.idstringBookings);
        String sql = "UPDATE bookings SET date ='"+da+"' WHERE ID ='"+id+"'";
        ps = con.prepareStatement(sql);
        ps.executeUpdate();

        ps.close();
        con.close();

        if (i == 1) {
            JOptionPane.showMessageDialog(null, "Database has been updated please click Refresh");

        }

    }

    catch (Exception e) {
            e.printStackTrace();
    }
}

Я также, кажется, получаю ошибку ...

net.ucanaccess.jdbc.UcanaccessSQLException: data exception: invalid datetime format
at net.ucanaccess.jdbc.UcanaccessPreparedStatement.executeUpdate(UcanaccessPreparedStatement.java:261)
at interfaceSystem.UpdateConn_Run.updateBooking(UpdateConn_Run.java:109)
at interfaceSystem.UpdateBooking_Run$2.actionPerformed(UpdateBooking_Run.java:284)
at javax.swing.AbstractButton.fireActionPerformed(Unknown Source)
at javax.swing.AbstractButton$Handler.actionPerformed(Unknown Source)
at javax.swing.DefaultButtonModel.fireActionPerformed(Unknown Source)
at javax.swing.DefaultButtonModel.setPressed(Unknown Source)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(Unknown Source)
at java.awt.Component.processMouseEvent(Unknown Source)
at javax.swing.JComponent.processMouseEvent(Unknown Source)
at java.awt.Component.processEvent(Unknown Source)
at java.awt.Container.processEvent(Unknown Source)
at java.awt.Component.dispatchEventImpl(Unknown Source)
at java.awt.Container.dispatchEventImpl(Unknown Source)
at java.awt.Component.dispatchEvent(Unknown Source)
at java.awt.LightweightDispatcher.retargetMouseEvent(Unknown Source)
at java.awt.LightweightDispatcher.processMouseEvent(Unknown Source)
at java.awt.LightweightDispatcher.dispatchEvent(Unknown Source)
at java.awt.Container.dispatchEventImpl(Unknown Source)
at java.awt.Window.dispatchEventImpl(Unknown Source)
at java.awt.Component.dispatchEvent(Unknown Source)
at java.awt.EventQueue.dispatchEventImpl(Unknown Source)
at java.awt.EventQueue.access$500(Unknown Source)
at java.awt.EventQueue$3.run(Unknown Source)
at java.awt.EventQueue$3.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(Unknown Source)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(Unknown Source)
at java.awt.EventQueue$4.run(Unknown Source)
at java.awt.EventQueue$4.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(Unknown Source)
at java.awt.EventQueue.dispatchEvent(Unknown Source)
at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
at java.awt.EventDispatchThread.run(Unknown Source)

Но это все еще смущает меня. , ,

  • В нем указан неверный формат даты и времени, поэтому я снова и снова менял формат. Даже попробовал формат в MS Access проблема все еще сохраняется.
  • Пытался не ставить дату как статичную. Я просто получаю "ноль".
  • Может кто-нибудь объяснить, почему static используется для обновления баз в PreparedStatements? Все еще смущает меня по сей день ... (Кажется, все в моем классе используют его, хотя я понятия не имею, почему)

Я прошу прощения за мой английский. Я не носитель языка, поэтому я ценю, если у вас есть вопросы, касающиеся грамматики ...

0
fireblazer10 21 Мар 2017 в 18:14

2 ответа

Лучший ответ

Поскольку вы используете PreparedStatement, вы должны использовать заполнители, и ваш код должен выглядеть следующим образом:

query = "UPDATE bookings SET date = ? WHERE id = ?";

preparedStatement = con.prepareStatement(query);
preparedStatement.setDate(1, da);
preparedStatement.setInt(2, id);
preparedStatement.executeUpdate();

Поскольку вы включаете Date объект в String, он будет проанализирован с использованием его метода toString(), и ваш оператор будет выглядеть следующим образом:

"UPDATE bookings SET date = 2000-01-12 WHERE id = 22"
3
LppEdd 21 Мар 2017 в 15:27

Я не занимаюсь Java, но ваш окончательный SQL для Access должен выглядеть так:

"UPDATE bookings SET date = #2017/03/21# WHERE ID = '1'";

Или, если ID числовой:

"UPDATE bookings SET date = #2017/03/21# WHERE ID = 1";

Таким образом, что-то вроде:

//datestring = da formatted as "2017/03/20"
String sql = "UPDATE bookings SET date =#"+datestring+"# WHERE ID ='"+id+"'";
1
Gustav 21 Мар 2017 в 15:56