免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1395 | 回复: 8
打印 上一主题 下一主题

[系统管理] 求一个算法 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-08-13 17:44 |只看该作者 |倒序浏览
数据库启动时间,打个比方是04/11/2012 05:13:24,今天的时间是08/13/2014 13:24:44
求他们之间的差,就是一共过了几天。闰年之类的也要考虑进去。
求一个shell的算法,基础差,算法之类的一直不太精通,求大神帮助!:wink:

论坛徽章:
12
技术图书徽章
日期:2014-07-11 16:27:5215-16赛季CBA联赛之山西
日期:2016-01-08 16:10:11操作系统版块每日发帖之星
日期:2015-08-01 06:20:002015亚冠之武里南联
日期:2015-06-11 01:12:162015年亚洲杯之阿联酋
日期:2015-03-20 11:41:462015年亚洲杯纪念徽章
日期:2015-03-18 18:08:422015年辞旧岁徽章
日期:2015-03-03 16:54:15丑牛
日期:2015-01-10 22:23:32天秤座
日期:2014-08-20 15:53:35水瓶座
日期:2014-08-11 12:08:51午马
日期:2014-07-23 23:03:38IT运维版块每日发帖之星
日期:2016-02-18 06:20:00
2 [报告]
发表于 2014-08-13 23:38 |只看该作者
本帖最后由 phanx 于 2014-08-13 23:44 编辑

回复 1# 6954658


    我算法也不精通,但是可以利用shell来算。

[root@fusionio ~]# more ./calcdate.sh
#!/bin/bash

datediff() {
    d1=$(date -d "$1" +%s)
    d2=$(date -d "$2" +%s)
    echo $(( (d1 - d2) / 86400 )) days
}
datediff "$1" "$2"






[root@fusionio ~]# ./calcdate.sh '2014-08-14 13:24:44'  '2012-04-11 05:13:24'
855 days



Oracle 可以用这个得到启动了多少天

SQL> select sysdate-startup_time DAYS from v$instance;

      DAYS
----------
12.3652778


MySQL 可以用这个语句得到

select now() - interval (variable_value/60/60/24) day from information_schema.global_status where variable_name='Uptime';

论坛徽章:
0
3 [报告]
发表于 2014-08-14 10:42 |只看该作者
回复 2# phanx


    先试试,多谢

论坛徽章:
0
4 [报告]
发表于 2014-08-14 15:17 |只看该作者
回复 2# phanx

报错。。。
date: illegal option -- d
Usage: date [-n][-u] [mmddHHMM[[cc]yy]] [+Field Descriptors]
Usage: date [-n][-u] [mmddHHMM[.SS[cc]yy]] [+Field Descriptors]
Usage: date [-a] [[+|-]sss.fff]
date: illegal option -- d
Usage: date [-n][-u] [mmddHHMM[[cc]yy]] [+Field Descriptors]
Usage: date [-n][-u] [mmddHHMM[.SS[cc]yy]] [+Field Descriptors]
Usage: date [-a] [[+|-]sss.fff]
/tmp/372080001.sh[3]:  (d1 - d2) / 86400 : bad number

论坛徽章:
12
技术图书徽章
日期:2014-07-11 16:27:5215-16赛季CBA联赛之山西
日期:2016-01-08 16:10:11操作系统版块每日发帖之星
日期:2015-08-01 06:20:002015亚冠之武里南联
日期:2015-06-11 01:12:162015年亚洲杯之阿联酋
日期:2015-03-20 11:41:462015年亚洲杯纪念徽章
日期:2015-03-18 18:08:422015年辞旧岁徽章
日期:2015-03-03 16:54:15丑牛
日期:2015-01-10 22:23:32天秤座
日期:2014-08-20 15:53:35水瓶座
日期:2014-08-11 12:08:51午马
日期:2014-07-23 23:03:38IT运维版块每日发帖之星
日期:2016-02-18 06:20:00
5 [报告]
发表于 2014-08-14 17:46 |只看该作者
回复 4# 6954658


   你是什么系统,什么版本?

论坛徽章:
0
6 [报告]
发表于 2014-08-14 23:07 |只看该作者
回复 5# phanx


    AIX, HPUX, SOLARIS, SLES11, RHEL6都有

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
7 [报告]
发表于 2014-08-15 08:27 |只看该作者
刚才试了一下, Solaris 中的 date 命令 没有 -d 参数.

我觉得楼主还是用数据中的函数吧. 反正你也是数据的维护, 用数据库中的函数, 可以保证兼容性.

论坛徽章:
0
8 [报告]
发表于 2014-08-15 11:44 |只看该作者
回复 7# q1208c


    新手上路,不太明白

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
9 [报告]
发表于 2014-08-15 11:54 |只看该作者
回复 8# 6954658

参考2楼说的, 数据库中的操作.
   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP