从Swing通过数据库实时搜索(或自动完成)

时间:2014-09-07 10:29:12

标签: java swing search jdbc autocomplete

我正在努力做到" google"搜索。用户输入内容 - 程序进入数据库并返回建议列表。我使用自动完成程序包,但不确定是否以正确的方式,因为我没有得到以下组合的建议列表,所以我可以看到并滚动浏览他,但它会自动从列表中选择一个建议并把他带到现场。此外,如果例如在第一个用户开始搜索字母"我.."自动完成功能完成工作(如上所述),然后如果用户想要输入其他文章的名称,例如" A .."组合只是刷新自己的普遍结果,所以搜索真的变得不可用。

class SuggestArticleNameActionListener implements ActionListener {
        @Override
        public void actionPerformed(ActionEvent e) {
            SwingWorker<Void, Void> worker = new SwingWorker<Void, Void>() {
                @Override
                protected Void doInBackground() throws Exception {
                    Vector<String> suggestions = new Vector<>();
                    try {
                        try (Connection conn = DriverManager.getConnection(JDBC_URL, LOGIN, PASSWORD)) {
                            PreparedStatement pstmt = conn.prepareStatement("SELECT name FROM Article WHERE Article.name LIKE ?");
                            String typed = comboBoxSearchArticle.getEditor().getItem().toString();
                                pstmt.setString(1, "%"+typed+"%");
                                ResultSet result = pstmt.executeQuery();
                                while (result.next()) suggestions.add(result.getString("name"));
                                            Collections.sort(suggestions);
                        }
                    } catch (SQLException ex) {
                        ex.printStackTrace();
                    }
                    comboBoxSearchArticle.setModel(new DefaultComboBoxModel<String>(suggestions.toArray(new String[suggestions.size()])));
                    return null;
                }

除了自动完成之外,还有其他问题:我使用的是正确的监听器吗?这个代码是否是线程安全的?如果有更有效的方法,请告诉我们。

1 个答案:

答案 0 :(得分:1)

最好实施 ItemListener

class SuggestArticleNameActionListener implements ItemListener{
    @Override
    public void itemStateChanged(ItemEvent event) {
       if (event.getStateChange() == ItemEvent.SELECTED) {
          Object item = event.getItem();
          // implement your logic here
       }
    }       
}