java - JDBC - 如何仅检索没有时间的日期(ORACLE 12c)

标签 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.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+"'";

关于java - JDBC - 如何仅检索没有时间的日期(ORACLE 12c),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35342628/

相关文章:

java - Android 中抛出异常的序列化

java - 当我处理 BatchUpdateException 时,executeBatch() 期间出现 SQLException

java - 在 JDBC 编程中在另一个查询中使用一个查询

jdbc - 在不同线程组下定义基于作用域的用户定义变量

java - 找到 [nvarchar2 (Types#OTHER)],但期待 [varchar2(255 char) (Types#VARCHAR)]

java - 当属性丢失时 Spring Boot 不会失败

java - 从 Sprite 表导入 Sprite

java - 使用 HttpClient 通过 java 客户端访问 power Bi 组

oracle - 如何在 oracle 12c 中为身份列查找 currval

Oracle 12c Forms & Reports setup_fmw_12.2.1.3.0_fr_win64.exe 安装错误 : self-extraction to C:\. ..... .tmp 失败