java.sql.SQLException:java.sql.Time的非法小时值’50’,值为’50:51:05

当我尝试从MySQL检索时间并将其设置为JLabel时,它会给我一个错误.

java.sql.SQLException: Illegal hour value ’50’ for java.sql.Time type
in value ’50:51:05.

任何人都可以建议我如何解决这个问题?

代码如下.

        String sql = "SELECT SEC_TO_TIME(SUM(TIME_TO_SEC(ot)))"
                + " FROM attendance"
                + " WHERE department = '"+department+"'"
                + "   AND date BETWEEN '"+dateChooser1+"' AND '"+dateChooser2+"'";
        st = con.createStatement();
        rst = st.executeQuery(sql);
        if(rst.next())
        {
            String time = rst.getString(1);
            oTimeTemp.setText(time);
        }
最佳答案
我解决了这是代码,

String sql = "SELECT SUM(TIME_TO_SEC(ot))"
            + " FROM attendance"
            + " WHERE department = '"+department+"'"
            + " AND date BETWEEN '"+dateChooser1+"' AND '"+dateChooser2+"'";
    st = con.createStatement();
    rst = st.executeQuery(sql);
    if(rst.next())
    {
            String time = rst.getString(1);
            Double dTime = Double.valueOf(time);
            int intTime = (int) dTime.doubleValue();
            String nTime = calculateTime(intTime);
            oTimeTemp.setText(nTime);
    }

private static String calculateTime(int totalSecs)
{
    int hours = totalSecs / 3600;
    int minutes = (totalSecs % 3600) / 60;
    int seconds = totalSecs % 60;

    String timeString = String.format("%02d:%02d:%02d",hours,minutes,seconds);
    return timeString;
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


mysql中%不能表示什么
mysql中的column什么意思
mysql中asc什么意思
mysql中的where什么意思
mysql中如何求百分比
mysql中no是不是关键字
mysql中column可以省略吗
mysql中before是什么意思
mysql中主键约束和唯一约束是什么关系
mysql中的varchar是什么意思
在mysql中用来查询结果的函数是?
mysql中enum是什么意思
mysql中on是什么意思
mysql中主键约束和唯一约束怎么区分出来的
mysql中表更新数据的命令是哪个
mysql中or的用法
mysql中的unique如何实现唯一
mysql中and和or的区别
desc在mysql中什么意思
mysql中的unique是什么意思