在java中从ms访问jdbcodbc查询数据库的正确语法是什么

时间:2013-04-12 10:01:57

标签: java ms-access

使用java eclipse查询ms访问数据库时出现此错误。

java.sql.SQLException: [Microsoft][ODBC Microsoft Access Driver] Undefined function txtIcNo.getText' in expression.
    at sun.jdbc.odbc.JdbcOdbc.createSQLException(Unknown Source)
    at sun.jdbc.odbc.JdbcOdbc.standardError(Unknown Source)
    at sun.jdbc.odbc.JdbcOdbc.SQLExecDirect(Unknown Source)
at sun.jdbc.odbc.JdbcOdbcStatement.execute(Unknown Source)
    at sun.jdbc.odbc.JdbcOdbcStatement.executeQuery(Unknown Source)
    at GetDataFromDB.retrieveDB(GetDataFromDB.java:103)
    at GetDataFromDB.actionPerformed(GetDataFromDB.java:79)
    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.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)"

我的代码如下

 public void retrieveDB() throws SQLException,ClassNotFoundException{
    //load JDBC Driver
    Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
    Connection con = DriverManager.getConnection("jdbc:odbc:PatientDB");
    String query = "SELECT * FROM PatientDB WHERE IC_No = txtIcNo.getText()";
    Statement stmt = con.createStatement();
    ResultSet rs = stmt.executeQuery(query);
    con.commit();
    while(rs.next()){
    if("txtIcNo.getText()"!=null){

    txtIcNo.setText(rs.getObject(1).toString());    
    txtName.setText(rs.getObject(2).toString());
    }
    else{
    System.out.println("Bye bye");
    }
    }
    con.close();
    }

1 个答案:

答案 0 :(得分:1)

如果这只是一个学习练习,那么试试

String query = "SELECT * FROM PatientDB WHERE IC_No = '" + txtIcNo.getText() + "'";

如果这是生产代码,那么使用上述内容。相反,对“SQL注入”攻击进行一些Web搜索,然后了解“参数化查询”并使用它们。