如何将多个 JCombobox 中的选定项目插入数据库 mysql? (Java)

How to insert selected items in multiple JCombobox into database mysql? (Java)

日期:(日组合框)(月组合框)(年组合框)

我有这三个组合框,我想获取所选项目并将其存储到字符串日期;存储到数据库 mysql。 我不是很擅长编码,我希望有人能帮助我.. 谢谢! :-)

我的代码:

JPanel panelDay = new JPanel();
panelDay.setBounds(224, 149, 56, 30);
panelStep2.add(panelDay);
panelDay.setBackground(new Color(224, 255, 255));
panelDay.setLayout(new BoxLayout(panelDay, BoxLayout.X_AXIS));

String[] dayStrings = {"31", "30", "29", "28", "27", "26", "25", "24", 
    "23", "22", "21", "20", "19", "18", "17", "16", "15", "14", "13",
    "12", "11", "10", "9","8", "7", "6","5", "4", "3", "2", "1", "Day" };

final JComboBox dayList = new JComboBox(dayStrings);
panelDay.add(dayList);
dayList.setSelectedIndex(31);   
dayList.setPreferredSize(new Dimension(200,130));
dayList.setVisible(true);           

JPanel panelMonth = new JPanel();
panelMonth.setBounds(292, 149, 70, 30);
panelStep2.add(panelMonth);
panelMonth.setBackground(new Color(224, 255, 255));
panelMonth.setLayout(new BoxLayout(panelMonth, BoxLayout.X_AXIS));

String[] monthStrings = {"12", "11", "10", "09",
    "08", "07", "06", "05", "04", "03", "02", "01", "Month" };

final JComboBox monthList = new JComboBox(monthStrings);
panelMonth.add(monthList);
monthList.setSelectedIndex(12); 
monthList.setPreferredSize(new Dimension(200,130));
monthList.setVisible(true);

JPanel panelYear = new JPanel();
panelYear.setBounds(375, 149, 70, 30);
panelStep2.add(panelYear);
panelYear.setBackground(new Color(224, 255, 255));
panelYear.setLayout(new BoxLayout(panelYear, BoxLayout.X_AXIS));

String[] yearStrings = {"1975", "1976", "1977", "1978", 
                                    "1979", "1980", 
                                    "1981", "1982",
                                    "1983", "1984", 
                                    "1985", "1986", 
                                    "1987", "1988", 
                                    "1989", "1990", 
                                    "1991", "1992",
                                    "1993", "1994", 
                                    "1995", "1996", 
                                    "1997", "1998", 
                                    "1999", "2000",
                                    "2001", "2002",
                                    "2003", "2004",
                                    "2005", "2006", 
                                    "2007", "2008",
                                    "2009", "2010", 
                                    "2011", "2012",
                                    "2013", "2014", 
                                    "2015", "Year" };

final JComboBox yearList = new JComboBox(yearStrings);
panelYear.add(yearList);
yearList.setSelectedIndex(12);  
yearList.setPreferredSize(new Dimension(200,130));
yearList.setVisible(true);

使用这个来初始化你的连击:

    cDay.removeAllItems();
    cMonth.removeAllItems();
    cYear.removeAllItems();

    cDay.addItem("Day");
    cMonth.addItem("Month");
    cYear.addItem("Year");

    for (int i = 1; i <= 31; i++) {
        cDay.addItem(i + "");
    }

    for (int i = 1; i <= 12; i++) {
        cMonth.addItem(i + "");
    }

    for (int i = 1975; i <= 2015; i++) {
        cYear.addItem(i + "");
    }

然后,设置值:

updateTo("19#1#41"); // index of values in combos

在哪里

private void updateTo(String data) {
    String[] list = data.split("#");
    cDay.setSelectedIndex(Integer.parseInt(list[0]));
    cMonth.setSelectedIndex(Integer.parseInt(list[1]));
    cYear.setSelectedIndex(Integer.parseInt(list[2]));
}

获取值:

private String getvalue() {
    return cDay.getSelectedIndex() + "#"
            + cMonth.getSelectedIndex() + "#"
            + cYear.getSelectedIndex();
}

存储这些数据需要您学习和使用mysql,或者简单地使用易于使用的 SQLite。

这个link真的很有用:http://www.tutorialspoint.com/sqlite/sqlite_java.htm

String day = dayList.getSelectedItem().toString();
String month = monthList.getSelectedItem().toString();
String year = yearList.getSelectedItem().toString();

if (!day.equals("Day") && !month.equals("Month") && !year.equals("Year")) {
     String dateAsString = day + "/" + month + "/" + year;
     SimpleDateFormat sdf = new SimpleDateFormat("dd/MM/yyyy");
     try {
         Date date = sdf.parse(dateAsString);
     } catch (ParseException e1) {}
}

您现在拥有字符串格式或 java.util.Date 格式的日期

与其使用 JComboBox 选择日期,更好的解决方案是使用 JXDatePicker,它在 Swing 编程中提供日期选择器

    import java.text.SimpleDateFormat;
import java.util.Calendar;

import javax.swing.JFrame;
import javax.swing.JPanel;

import org.jdesktop.swingx.JXDatePicker;

    @SuppressWarnings("serial")
    public class DatePickerExample extends JPanel {

        public static void main(String[] args) {
            JFrame frame = new JFrame("JXPicker Example");
            JPanel panel = new JPanel();

            frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
            frame.setBounds(400, 400, 250, 100);


            JXDatePicker picker = new JXDatePicker();
            picker.setDate(Calendar.getInstance().getTime());
            picker.setFormats(new SimpleDateFormat("dd.MM.yyyy"));

            panel.add(picker);
            frame.getContentPane().add(panel);

            frame.setVisible(true);
        }
    }

无需担心从不同的组合框中选择文本,并且还会为您的应用程序提供更好的UI

注意:要么使用 swingx jar 的 Maven 依赖项 或者您可以从这里下载它: http://www.java2s.com/Code/Jar/s/Downloadswingx094jar.htm

Edit : As Requested 如何从 DatePicker 获取选定的日期

JFormattedTextField editor = picker.getEditor();
Date dateInDatePicker = (Date) editor.getValue();