Java JDBC-如何只检索日期而不检索时间(ORACLE 12c)

Java JDBC-如何只检索日期而不检索时间(ORACLE 12c),java,jdbc,oracle12c,Java,Jdbc,Oracle12c,我正在尝试构建一个小型控制台应用程序,该应用程序接收公司员工的ID并打印其详细信息。一切都很顺利,但当涉及到员工的任命日期时,它会给出日期和时间。 示例:“2005-03-10 00:00:00.0” 我想做的是,我只想要“2005-03-10”。如何做到这一点?代码如下: public static void main(String[] args) { Scanner read = new Scanner(System.in); try { Class.for

我正在尝试构建一个小型控制台应用程序,该应用程序接收公司员工的ID并打印其详细信息。一切都很顺利,但当涉及到员工的任命日期时,它会给出日期和时间。 示例:“2005-03-10 00:00:00.0”

我想做的是,我只想要“2005-03-10”。如何做到这一点?代码如下:

public static void main(String[] args) {

    Scanner read = new Scanner(System.in);
    try
    {
    Class.forName("oracle.jdbc.driver.OracleDriver");
    Connection conn = DriverManager.getConnection("jdbc:oracle:thin:sys/password@//localhost:1521:xe");
    Statement st = conn.createStatement();

    System.out.print("Enter the id of employee: ");
    String id = read.next();

    String sql = "SELECT E.EMP_NAME, D.DEPT_NAME, ES.ROLE, ES.DATE_OF_APPOINTMENT, S.SALARY "
            + "FROM EMPLOYEE E, DEPARTMENT D, DEPARTMENT_ROLE DR, EMPLOYEE_SERVICE ES, SALARY S "
            + "WHERE E.EMP_ID = ES.EMP_ID AND E.EMP_ID=S.EMP_ID AND D.DEPT_ID=DR.DEPT_ID AND DR.ROLE=ES.ROLE "
            + "AND E.EMP_ID='"+id+"'";

    ResultSet rs = st.executeQuery(sql);

    while(rs.next()){
        System.out.println("\n\nEmployee Name\t: "+rs.getString(1)+"\nDepartment\t: "+rs.getString(2)
                +"\nRole\t\t: "+rs.getString(3)+"\nAppointed On\t: "+rs.getString(4)+"\nSalary\t\t: "+rs.getString(5));
    }
    st.close();
    conn.close();
    read.close();
    }
    catch(SQLException e){
        e.printStackTrace();
    }
    catch(Exception se){
        se.printStackTrace();
    }
}
输出如下所示:

输入员工id:CCT003

员工姓名:约瑟夫·布朗

部门:人力资源部

职位:行政招聘人员

任命日期:2006-02-13 00:00:00.0

薪金:118000

请帮忙。
谢谢。

既然您正在以字符串形式检索数据,您只需再添加一个步骤并格式化即可

String sql = "SELECT E.EMP_NAME, D.DEPT_NAME, ES.ROLE, TO_CHAR(ES.DATE_OF_APPOINTMENT,'YYYY-MM-DD') AS DATE_OF_APPOINTMENT, S.SALARY "
            + "FROM EMPLOYEE E, DEPARTMENT D, DEPARTMENT_ROLE DR, EMPLOYEE_SERVICE ES, SALARY S "
            + "WHERE E.EMP_ID = ES.EMP_ID AND E.EMP_ID=S.EMP_ID AND D.DEPT_ID=DR.DEPT_ID AND DR.ROLE=ES.ROLE "
            + "AND E.EMP_ID='"+id+"'";

您可以修改SQL查询并使用Oracle TO_CHAR()函数:

    TO_CHAR(ES.DATE_OF_APPOINTMENT, 'YYYY-MM-DD') as DATE_OF_APPOINTMENT

您需要的是DateFormatter()
SimpleDataFormat df=newSimpleDataFormat(“yyyy-MM-dd”)。由于您将其作为字符串获取,请使用函数。或者将其作为日期,请参见下文的评语。他给专栏加了一个别名,这是我写的。它们是JDBC的一个好主意,我通过回答更新了它们。谢谢你)