我正在努力做到" 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;
}
除了自动完成之外,还有其他问题:我使用的是正确的监听器吗?这个代码是否是线程安全的?如果有更有效的方法,请告诉我们。
答案 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
}
}
}