首页 > 解决方案 > 我正在尝试根据参数从关系表中提取最后一个值

问题描述

我正在尝试根据参数从关系表中提取最后一个值,它给了我这个错误

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:您的 SQL 语法有错误;检查与您的 MariaDB 服务器版本相对应的手册,以在第 1 行的 '1 * FROM version WHERE codeProject = '7' ORDER BY idVersion DESC' 附近使用正确的语法

public class VersionDAO {
    ConexionSQL conectar = new ConexionSQL();
    Connection con;
    PreparedStatement ps;
    ResultSet rs;
    String changeVersion;

    public Version buscarVer(int bus, Proyecto p) {
        String sql = "SELECT TOP 1 id, name FROM version WHERE codeProject = '"+ bus +"' ORDER BY idVersion DESC";

        try {
            con = conectar.getConexionSQL();
            ps=con.prepareStatement(sql);
            rs=ps.executeQuery();
            Version ver = new Version();
            while (rs.next()) {
                ver.setIdversion(rs.getInt(1));
                ver.setNameVersion(rs.getString(2));
                changeVersion = rs.getString(2);
            }       
            return ver;
        } catch(Exception e){
            e.printStackTrace();
        }
        return null;
    }   

}

标签: javamysqlsqldatabasesql-order-by

解决方案


MySQL 不支持TOP 1,您需要LIMIT 1代替 - 它位于查询的末尾,而不是在ORDER BY子句之后,而不是在SELECT关键字之后。

SELECT id, name 
FROM version 
WHERE codeProject = ? 
ORDER BY idVersion DESC LIMIT 1

请注意,您应该使用参数化语句,而不是将变量转换为查询字符串:这使查询更高效,在必要时处理转义(例如,如果您的参数包含嵌入式引号),并保护您的代码免受 SQL注射。


推荐阅读