JDBC 使用别名时结果集不起作用我收到“java.sql.SQLSyntaxErrorException: ORA-00905: 缺少关键字”

JDBC resultset not working when using aliases I receive " java.sql.SQLSyntaxErrorException: ORA-00905: missing keyword"

我想执行这个查询,但它在不使用变量的情况下给了我一个错误,但它给了我一个错误 ORA-00905: 缺少关键字。 我在 SQL Developer 中测试了查询,它 运行 没有错误。我可能认为这是 JDBC 的驱动程序问题或语法问题。但我不知道这是代码:

    public List<ReimbBean> getAllReimb() {

    String sql = "select reim.reimb_id, reim.reimb_amount,"
            + "reim.reimb_submitted, reim.reimb_resolved, "
            + "CONCAT(CONCAT(u.user_first_name,' '),"
            + " u.user_last_name) AS \"REIMB_AUTHOR\", "
            + "reim.REIMB_RESCRIPTION, rst.REIMB_STATUS, "
            + "rtype.REIMB_TYPE, CONCAT(CONCAT(urs.user_first_name,'   '), "
            + "urs.user_last_name) AS \"REIMB_RESOLVER\""
            + "FROM ERS_REIMBURSTMENT reim"
            + "LEFT JOIN ERS_USERS u"
            + "ON u.ERS_USERS_ID = reim.REIMB_AUTHOR"
            + "LEFT JOIN ERS_REIMBURSTMENT_STATUS rst"
            + "ON rst.REIMB_STATUS_ID = reim.REIMB_STATUS_ID"
            + "LEFT JOIN ERS_REIMBURSTMENT_TYPE rtype"
            + "ON rtype.reimb_type_id = reim.REIMB_TYPE_ID"
            + "LEFT JOIN ERS_USERS urs"
            + "ON urs.ERS_USERS_ID = reim.REIMB_RESOLVER"
            + "ORDER BY reim.reimb_id";
  List<ReimbBean> reimbAllList = new ArrayList<>();  
  ReimbBean reimb = new ReimbBean();

  try {
       PreparedStatement preparedStatement =    conn6.prepareStatement(sql);

            ResultSet rs = preparedStatement.executeQuery(); 

        while(rs.next()){

            reimb.setReimbAmount(rs.getDouble("reimb_Amount"));
            reimb.setReimbDescript(rs.getString("reimb_Description"));
            reimb.setReimbSubmitted(rs.getTimestamp("reimb_Submitted"));
            reimb.setReimbAuthor(rs.getInt("reimb_Author"));
            reimb.setReimbResolved(rs.getTimestamp("reimb_Resolved"));
            reimb.setReimbResolver(rs.getInt("reimb_Resolver"));
            reimb.setReimbStatusID(rs.getInt("reimb_Status_ID"));
            reimb.setReimbTypeID(rs.getInt("reimb_Type_ID"));

            reimbAllList.add(reimb);
        }   

我在网上看到 preapareStatement 无法仅绑定对象变量,所以另一种方法是显式定义它们,所以我创建了一个声明部分并将字段替换为字符串变量,但错误仍然存​​在。

您在很多这些字符串的末尾缺少空格:

String sql = "select reim.reimb_id, reim.reimb_amount,"
           + "reim.reimb_submitted, reim.reimb_resolved, "
           + "CONCAT(CONCAT(u.user_first_name,' '),"
           + " u.user_last_name) AS \"REIMB_AUTHOR\", "
           + "reim.REIMB_RESCRIPTION, rst.REIMB_STATUS, "
           + "rtype.REIMB_TYPE, CONCAT(CONCAT(urs.user_first_name,'   '), "
           + "urs.user_last_name) AS \"REIMB_RESOLVER\" " // Here
           + "FROM ERS_REIMBURSTMENT reim " // and here
           + "LEFT JOIN ERS_USERS u " // and here
           + "ON u.ERS_USERS_ID = reim.REIMB_AUTHOR " // and here
           + "LEFT JOIN ERS_REIMBURSTMENT_STATUS rst " // and here
           + "ON rst.REIMB_STATUS_ID = reim.REIMB_STATUS_ID " // and here
           + "LEFT JOIN ERS_REIMBURSTMENT_TYPE rtype " // and here
           + "ON rtype.reimb_type_id = reim.REIMB_TYPE_ID " // and here
           + "LEFT JOIN ERS_USERS urs " // and here
           + "ON urs.ERS_USERS_ID = reim.REIMB_RESOLVER " // and here
           + "ORDER BY reim.reimb_id";