Java JDBC-如何只检索日期而不检索时间(ORACLE 12c)
我正在尝试构建一个小型控制台应用程序,该应用程序接收公司员工的ID并打印其详细信息。一切都很顺利,但当涉及到员工的任命日期时,它会给出日期和时间。 示例:“2005-03-10 00:00:00.0” 我想做的是,我只想要“2005-03-10”。如何做到这一点?代码如下: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
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的一个好主意,我通过回答更新了它们。谢谢你)