使用SQL计算宝宝每次吃奶的时间间隔(续)
本文是《使用SQL计算宝宝每次吃奶的时间间隔》的续篇,因为我工作繁忙,时常不能及时帮助媳妇儿记录,为了让不懂数据库的媳妇儿也可以自己用手机熟练操作。我继续做了一些修正和封装:
- 1.给媳妇儿的手机下载一个terminal终端软件termius,实现只需打开app就可以连接到环境;
- 2.跟媳妇儿进一步沟通需求,按她能够接受的使用习惯来修正并封装程序,原则是尽可能的简化操作。
先来看下改进后最终的使用效果:
--1.手机上打开termius软件,点击进入到终端,输入 h 可以看到所有命令的说明:
[oracle@jystdrac1 ~]$ h
**Command for Baby's feed_time:**
Usage:
v - View Today's Result.
vv <'mmdd'> - View one day's Result.
i - Insert a row using current time.
ii <'mmdd hh24:mi'> - Insert a row using input time.
d <id> - Delete a mistake row by id.
u <label> <id> - Update a mistake row by id.
h - Help
--2.输入 v 可以看到今天的喂奶时间和间隔:
[oracle@jystdrac1 ~]$ v
View Today's Result:
ID FEED_TIME L LAG(min) LAG(h)
---------- ----------- - ---------- ----------
53 12-15 01:00 N 140 2.33
54 12-15 04:08 N 188 3.13
55 12-15 07:35 N 207 3.45
56 12-15 10:40 N 185 3.08
69 12-15 13:16 N 156 2.6
70 12-15 14:32 N 76 1.27
82 12-15 17:14 N 163 2.71
83 12-15 19:15 N 121 2.01
8 rows selected.
--3.输入 i 可以直接以当前系统时间插入一条数据,并显示插入后的结果:
[oracle@jystdrac1 ~]$ i
Insert a row using current time:
1 row created.
Commit complete.
View Today's Result:
ID FEED_TIME L LAG(min) LAG(h)
---------- ----------- - ---------- ----------
53 12-15 01:00 N 140 2.33
54 12-15 04:08 N 188 3.13
55 12-15 07:35 N 207 3.45
56 12-15 10:40 N 185 3.08
69 12-15 13:16 N 156 2.6
70 12-15 14:32 N 76 1.27
82 12-15 17:14 N 163 2.71
83 12-15 19:15 N 121 2.01
94 12-15 23:02 N 227 3.78
9 rows selected.
--4.输入 d <id> 可以删除id对应的那行记录,并显示删除后的结果:
[oracle@jystdrac1 ~]$ d 94
Delete a mistake row by id:
Enter value for id: old 1: delete from t_baby where id = &id
new 1: delete from t_baby where id = 94
1 row deleted.
Commit complete.
View Today's Result:
ID FEED_TIME L LAG(min) LAG(h)
---------- ----------- - ---------- ----------
53 12-15 01:00 N 140 2.33
54 12-15 04:08 N 188 3.13
55 12-15 07:35 N 207 3.45
56 12-15 10:40 N 185 3.08
69 12-15 13:16 N 156 2.6
70 12-15 14:32 N 76 1.27
82 12-15 17:14 N 163 2.71
83 12-15 19:15 N 121 2.01
8 rows selected.
--5.输入 u <label> <id> 可以更新指定id的label值,比如将id=55的记录label值修改为'L',代表这次喂奶量很少,不参与计算
[oracle@jystdrac1 ~]$ u l 55
Update a mistake row by id:
Enter value for label: Enter value for id: old 1: update t_baby set label = upper('&label') where id = &id
new 1: update t_baby set label = upper('l') where id = 55
1 row updated.
Commit complete.
View Today's Result:
ID FEED_TIME L LAG(min) LAG(h)
---------- ----------- - ---------- ----------
53 12-15 01:00 N 140 2.33
54 12-15 04:08 N 188 3.13
56 12-15 10:40 N 392 6.53
69 12-15 13:16 N 156 2.6
70 12-15 14:32 N 76 1.27
82 12-15 17:14 N 163 2.71
83 12-15 19:15 N 121 2.01
7 rows selected.
--6.输入 u <label> <id> 可以更新指定id的label值,比如将id=55的记录label值修改回'N',代表这次喂奶量正常,参与计算
[oracle@jystdrac1 ~]$ u n 55
Update a mistake row by id:
Enter value for label: Enter value for id: old 1: update t_baby set label = upper('&label') where id = &id
new 1: update t_baby set label = upper('n') where id = 55
1 row updated.
Commit complete.
View Today's Result:
ID FEED_TIME L LAG(min) LAG(h)
---------- ----------- - ---------- ----------
53 12-15 01:00 N 140 2.33
54 12-15 04:08 N 188 3.13
55 12-15 07:35 N 207 3.45
56 12-15 10:40 N 185 3.08
69 12-15 13:16 N 156 2.6
70 12-15 14:32 N 76 1.27
82 12-15 17:14 N 163 2.71
83 12-15 19:15 N 121 2.01
8 rows selected.
--7.输入 ii <'mmdd hh24:mi'> 可以插入指定日期和时间
[oracle@jystdrac1 ~]$ ii '1215 23:00'
Insert a row using input time(mmdd mi:ss) eg: 1215 10:00
Enter value for feed_time: old 1: insert into t_baby(id,feed_time) values(s1.nextval,to_date('&feed_time','mmdd hh24:mi'))
new 1: insert into t_baby(id,feed_time) values(s1.nextval,to_date('1215 23:00','mmdd hh24:mi'))
1 row created.
Commit complete.
View Today's Result:
ID FEED_TIME L LAG(min) LAG(h)
---------- ----------- - ---------- ----------
53 12-15 01:00 N 140 2.33
54 12-15 04:08 N 188 3.13
55 12-15 07:35 N 207 3.45
56 12-15 10:40 N 185 3.08
69 12-15 13:16 N 156 2.6
70 12-15 14:32 N 76 1.27
82 12-15 17:14 N 163 2.71
83 12-15 19:15 N 121 2.01
95 12-15 23:00 N 225 3.74
9 rows selected.
--8.删除id=95的这条测试记录
[oracle@jystdrac1 ~]$ d 95
Delete a mistake row by id:
Enter value for id: old 1: delete from t_baby where id = &id
new 1: delete from t_baby where id = 95
1 row deleted.
Commit complete.
View Today's Result:
ID FEED_TIME L LAG(min) LAG(h)
---------- ----------- - ---------- ----------
53 12-15 01:00 N 140 2.33
54 12-15 04:08 N 188 3.13
55 12-15 07:35 N 207 3.45
56 12-15 10:40 N 185 3.08
69 12-15 13:16 N 156 2.6
70 12-15 14:32 N 76 1.27
82 12-15 17:14 N 163 2.71
83 12-15 19:15 N 121 2.01
8 rows selected.
--9.使用 vv 'mmdd' 可以显示指定日期的喂奶间隔情况:
[oracle@jystdrac1 ~]$ vv 1214
View Today's Result:
Enter value for feed_time: Enter value for feed_time: old 2: from (select t.*, lag(feed_time) over(order by id) l_time from t_baby t where label <> 'L') where feed_time >= to_date('&feed_time','mmdd') and feed_time < to_date('&feed_time','mmdd') + 1
new 2: from (select t.*, lag(feed_time) over(order by id) l_time from t_baby t where label <> 'L') where feed_time >= to_date('1214','mmdd') and feed_time < to_date('1214','mmdd') + 1
ID FEED_TIME L LAG(min) LAG(h)
---------- ----------- - ---------- ----------
41 12-14 01:55 N 265 4.42
42 12-14 04:58 N 183 3.05
43 12-14 08:25 N 207 3.45
44 12-14 11:23 N 178 2.97
45 12-14 12:23 N 60 1
46 12-14 15:00 N 157 2.62
47 12-14 17:22 N 142 2.37
48 12-14 18:45 N 83 1.38
49 12-14 22:40 N 235 3.92
9 rows selected.
经过一番演示,媳妇儿的反馈是非常满意的,实际她最常用的还是v和i,非常方便,其他命令偶尔使用,其实只需记住h可以获取到帮助即可。下面将本次的修正和封装过程记录一下:
1.环境变量配置别名
为了简化操作,我将环境变量设置一些别名。
[oracle@jystdrac1 ~]$ cat ~/.bash_profile
# 这里省略原有环境变量内容,下面为在源文件基础上追加的内容:
# Alias for baby's feed_time:
alias h=/home/oracle/baby_readme.sh
alias v=/home/oracle/baby_view.sh
alias i=/home/oracle/baby_insert.sh
alias d=/home/oracle/baby_delete.sh
alias u=/home/oracle/baby_update.sh
alias ii=/home/oracle/baby_insert_diy.sh
alias vv=/home/oracle/baby_view_diy.sh
2.系统shell脚本
##baby_readme.sh
vi baby_readme.sh
#!/bin/bash
# script:baby_readme.sh
# version:1.01
#-------------------------------------------------------------
echo "**Command for Baby's feed_time:**"
echo "Usage:"
echo " v - View Today's Result."
echo " vv <'mmdd'> - View one day's Result."
echo " i - Insert a row using current time."
echo " ii <'mmdd hh24:mi'> - Insert a row using input time."
echo " d <id> - Delete a mistake row by id."
echo " u <label> <id> - Update a mistake row by id."
echo " h - Help"
#-------------------------------------------------------------
baby_view.sh
vi baby_view.sh
#!/bin/bash
# script:baby_view.sh
# version:1.01
#-------------------------------------------------------------
sqlplus -S test/test <<EOF
PROMPT View Today's Result:
@v3
EOF
#-------------------------------------------------------------
baby_insert.sh
vi baby_insert.sh
#!/bin/bash
# script:baby_insert.sh
# version:1.01
#-------------------------------------------------------------
sqlplus -S test/test <<EOF
PROMPT Insert a row using current time:
@i1
PROMPT View Today's Result:
@v3
EOF
#-------------------------------------------------------------
baby_delete.sh
vi baby_delete.sh
#!/bin/bash
# script:baby_delete.sh
# version:1.01
#-------------------------------------------------------------
sqlplus -S test/test <<EOF
PROMPT Delete a mistake row by id:
@d1
$1
commit;
PROMPT View Today's Result:
@v3
EOF
#-------------------------------------------------------------
baby_insert_diy.sh
vi baby_insert_diy.sh
#!/bin/bash
# script:baby_insert_diy.sh
# version:1.01
#-------------------------------------------------------------
sqlplus -S test/test <<EOF
PROMPT Insert a row using input time(mmdd mi:ss) eg: 1215 10:00
@i2
$1
commit;
PROMPT View Today's Result:
@v3
EOF
#-------------------------------------------------------------
baby_update.sh
vi baby_update.sh
#!/bin/bash
# script:baby_update.sh
# version:1.01
#-------------------------------------------------------------
sqlplus -S test/test <<EOF
PROMPT Update a mistake row by id:
@u1
$1
$2
commit;
PROMPT View Today's Result:
@v3
EOF
#-------------------------------------------------------------
baby_view_diy.sh
vi baby_view_diy.sh
#!/bin/bash
# script:baby_view.sh
# version:1.01
#-------------------------------------------------------------
sqlplus -S test/test <<EOF
PROMPT View one day's Result:
@v4
$1
$1
EOF
#-------------------------------------------------------------
3.底层SQL文本
--echo "v - View Today's Result."
[oracle@jystdrac1 ~]$ cat v3.sql
SELECT
id,
to_char(feed_time, 'mm-dd hh24:mi') "FEED_TIME",
label,
round((feed_time - l_time) * 24 * 60) "LAG(min)",
round((feed_time - l_time) * 24, 2) "LAG(h)"
FROM
(
SELECT
t.*,
LAG(feed_time) OVER(ORDER BY id) l_time
FROM
t_baby t
WHERE
label <> 'L'
)
WHERE
feed_time >= trunc(sysdate)
/
-- echo " vv <'mmdd'> - View one day's Result."
[oracle@jystdrac1 ~]$ cat v4.sql
SELECT
id,
to_char(feed_time, 'mm-dd hh24:mi') "FEED_TIME",
label,
round((feed_time - l_time) * 24 * 60) "LAG(min)",
round((feed_time - l_time) * 24, 2) "LAG(h)"
FROM
(
SELECT
t.*,
LAG(feed_time) OVER(ORDER BY id) l_time
FROM
t_baby t
WHERE
label <> 'L'
)
WHERE
feed_time >= TO_DATE('&feed_time', 'mmdd')
AND feed_time < TO_DATE('&feed_time', 'mmdd') + 1
/
--echo "i - Insert a row using current time."
[oracle@jystdrac1 ~]$ cat i1.sql
insert into t_baby(id,feed_time) values(s1.nextval,sysdate)
/
commit
/
--echo "ii - Insert a row using input time."
[oracle@jystdrac1 ~]$ cat i2.sql
insert into t_baby(id,feed_time) values(s1.nextval,to_date('&feed_time','mmdd hh24:mi'))
/
--echo "d - Delete a mistake row by id. "
[oracle@jystdrac1 ~]$ cat d1.sql
delete from t_baby where id = &id
/
--echo "u - Update a mistake row by id."
[oracle@jystdrac1 ~]$ cat u1.sql
update t_baby set label = upper('&label') where id = &id
/
SQL文本独立出来也方便后续需求有变化时快速更改。
使用SQL计算宝宝每次吃奶的时间间隔(续)的更多相关文章
- 使用SQL计算宝宝每次吃奶的时间间隔(数据保障篇)
目前程序从功能上其实已经完全满足客户(当然我这里的客户都是指媳妇儿^_^)需求,具体可参考: 使用SQL计算宝宝每次吃奶的时间间隔 使用SQL计算宝宝每次吃奶的时间间隔(续) 那么本篇 使用SQL计算 ...
- 使用SQL计算宝宝每次吃奶的时间间隔
需求:媳妇儿最近担心宝宝的吃奶时间不够规律,网上说是正常平均3小时喂奶一次,让我记录下每次的吃奶时间,分析下实际是否偏差很大,好在下次去医院复查时反馈给医生. 此外,还要注意有时候哭闹要吃奶,而实际只 ...
- SQL 计算列
SQL计算列,可以解决一般标量计算(数学计算,如ColumnA*ColumnB)的问题,而子查询计算(如select sum(salary) from tableOther where id=’ABC ...
- sql计算经纬度得出最近距离的公式
sql计算经纬度得出最近距离的公式 //根据经纬度计算两点距离 mappoint //数据库已有字段,商家经纬度 实例:113.272148,23.147299 $lon = "" ...
- SQL计算时间差并排除周末
SQL计算时间差并排除周末 CREATE FUNCTION DI_FN_GET_WorkDay (@begin DATETIME , @end DATETIME ) RETURNS int BEGIN ...
- 【HANA系列】SAP HANA SQL计算两个日期的差值
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA SQL计算两个 ...
- 【HANA系列】SAP HANA SQL计算某日期是当月的第几天
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA SQL计算某日 ...
- 【HANA系列】SAP HANA SQL计算某日期是当年的第几天
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA SQL计算某日 ...
- Java工作流引擎节点接收人设置“按自定义SQL计算”系列讲解
关键字: 驰骋工作流程快速开发平台 工作流程管理系统 工作流引擎 asp.net工作流引擎 java工作流引擎. 开发者表单 拖拽式表单 工作流系统CCBPM节点访问规则接收人规则 适配数据库: o ...
随机推荐
- Github PageHelper 原理解析
任何服务对数据库的日常操作,都离不开增删改查.如果一次查询的纪录很多,那我们必须采用分页的方式.对于一个Springboot项目,访问和查询MySQL数据库,持久化框架可以使用MyBatis,分页工具 ...
- hdu 1263 水果 (嵌套 map)
水果Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submissio ...
- nyoj 26-孪生素数问题(打表)
26-孪生素数问题 内存限制:64MB 时间限制:3000ms Special Judge: No accepted:10 submit:43 题目描述: 写一个程序,找出给出素数范围内的所有孪生素数 ...
- (三十六)golang--文件的基本操作
文件程序中是以流的形式操作的. 流:数据在数据源(文件)和程序(内存)之间经历的路径: 输入流:数据从数据源到程序的路径: 输出流:数据从程序到数据源的路径: 常用的文件操作和函数: 1.常用的文件操 ...
- 京东物流出问题了?褥了30块羊毛 & 浅析系统架构
本人亲身经历,但后续的流程分析都是个人猜测的,毕竟没有实际做过这块的业务. 订单物流阻塞经过 火热的双11刚刚退去,截止今日,我在京东购买的矿泉水终于到货啦,下单两箱还只收到了一箱 :( ,从下单到收 ...
- Redis集群同步问题
之前被面试官问到:Redis集群中主从数据同步是从库异步读取主库,那么Redis集群其他主与主之间的数据是怎么共享的呢?或者说是怎么同步的? emmmm……当时我就懵逼了,这不是考试范围啊卧槽~只能老 ...
- 01-tornado学习笔记-Tornado简介
01-Tornado简介 Tornado是使用Python编写的一个强大的.可扩展的Web服务器.它在处理严峻的网络流量时表现得足够强健,但却在创建和编写时有着足够的轻量级,并能够被用在大量的应用 ...
- Netty-主从Reactor多线程模式的源码实现
Netty--主从Reactor多线程模式的源码实现 总览 EventLoopGroup到底是什么? EventLoopGroup是一个存储EventLoop的容器,同时他应该具备线程池的功能. gr ...
- day20191012笔记
课程默写笔记: 1.程序架构 C/S 客户端/服务器端 B/S 浏览器/服务器端 2.Tomcat应用服务器 tomcat默认端口号是80:tomcat配置文件中通常端口的定义是8080: 3.使用开 ...
- 用Spring Security, JWT, Vue实现一个前后端分离无状态认证Demo
简介 完整代码 https://github.com/PuZhiweizuishuai/SpringSecurity-JWT-Vue-Deom 运行展示 后端 主要展示 Spring Security ...