查询某个时间段(日期和时间分别用两个DateTimePicker表示,是分开的)之间的记录的sql语句

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了查询某个时间段(日期和时间分别用两个DateTimePicker表示,是分开的)之间的记录的sql语句相关的知识,希望对你有一定的参考价值。

数据库的设计是day字段表示日期,time字段表示时间,我用以下sql语句查询某个时间段之间的记录(da1:=DateTimePicker1.date , da2:=DateTimePicker2.date , tm1:=DateTimePicker3.time ,tm2:=DateTimePicker4.time)我想查询da1的tm1到da2的tm2之间数据sql语句:(day between '''+da1+''' and '''+da2+''') and (time between '''+tm1+''' and '''+tm2+''')';
但如果da1和da2不是同一天的话查询结果就达不到我预期的要求

例如数据库中有一条记录 day time2006-06-12 11:20:30我用sql语句: select * from tab where (day between '2006-06-12' and '2006-06-12') and (time between '10:10:20' and '11:30:20');就能查询到上面那条记录,但如果sql语句改为:select * from tab where (day between '2006-06-12' and '2006-06-13') and (time between '09:10:20' and '09:10:20') 就不能查询到上面那条记录。请问这样的查询sql语句该怎么写?

参考技术A 可能你sql写错了吧注意看你的sql
and (time between '09:10:20' and '09:10:20')这个查不到
(time between '10:10:20' and '11:30:20') 这个能查到
参考技术B 如果你写成select * from tab where (day between '2006-06-12' and '2006-06-13') and (time between '10:10:20' and '11:30:20')这样有结果吗追问

不对,这样就没有6月12日11:30:20之后和6月13日10:10:20之前的数据

追答

那你可以这样写select * from tab where (day between '2006-06-12' and '2006-06-13') and (time between '00:00:00' and '11:59:59')这真的不是一个好的设计

追问

这样写要是别的时间就达不到预期了
不过我已经解决了 ,谢谢大家了

本回答被提问者采纳
参考技术C 不知道楼主为为什么要这么设计数据库,日期和时间要分开设计,这明显是有问题的! 也不科学!追问

我是从txt读取的内容存入数据库的,本来就是分开的

每个字符串每出现第 2 次,分别用文件的第 n 行替换两个不同的字符串

【中文标题】每个字符串每出现第 2 次,分别用文件的第 n 行替换两个不同的字符串【英文标题】:replace two different strings with the nth line of a file every 2 nth occurrences of each string separately 【发布时间】:2021-12-20 08:17:45 【问题描述】:

我正在尝试使用以下command_line01home_cool 的第一次和第二次出现分别替换为1.txt 的第一行,然后继续替换home_cool01 的第一次和第二次出现也分别由1.txt 的第一行,然后..,用1.txt 的第二行单独替换第三和第四次出现的home_cool。等等,即每2 nth 出现home_coolhome_cool01,分别用1.txt 的第n 行替换两个字符串。

我试过command_line01 波纹管:

awk 'NR==FNR a[NR]=$0; next /home_cool01/gsub("home_cool01", a[++i<3]) /home_cool/gsub("home_cool", a[++j<3]) 1' 1.txt 0.txt > 2.txt

但这仅适用于 前两次出现,因为接下来的两次出现 home_coolhome_cool01nothing 替换,如下所示:

"#sun\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree()\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree()\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree()\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree()\t",
"machine(shoes_shirt.shop)\t",

这是我的两个源文件:

0.txt:

"#sun\t",
"car_snif = house.group_tree(home_cool)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tre(home_cool)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool01)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool01)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool01)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool01)\t",
"machine(shoes_shirt.shop)\t",

1.txt:

(food, apple, sky, cat,blue,)(bag, tortoise,)
(food, apple, sky, cat,blue,)(bag,)
(food, apple, sky, cat,blue,)(bag, moon, tortoise,)

而我想要的输出 2.txt 是:

"#sun\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag,))\t",
"machine(shoes_shirt.shop)\t",

编辑:来自@markp-fuso cmets:

1 - 如果有多个条目,如果已​​经完成第一个条目的处理,我将从第二个重新启动。

2 - 如果我有超过 6 个 home_coool 条目...我从 1.txt 的开头继续。

3 - 我不想仅限于两种研究模式,所以当有home_coool02home_coool03、...、home_coool_some_sufix 时,它应该是一个合适的解决方案,但我需要保持我最初发布的 MWE

【问题讨论】:

如果输入是home_coolhome_cool01home_cool 怎么办...您是重新启动第二个home_cool 的计数器还是从上次中断的地方继续?如果您有超过 6 个 home_cool 条目会发生什么...您是继续使用来自 1.txt 的最后一个条目还是从 1.txt 的开头重新开始?您是否需要担心其他搜索模式,例如home_cool02home_cool04home_cool_some_other_suffix 等? 我认为您可能需要阅读有关 % 运算符的信息。 @Luuk 我会阅读谢谢! @markp-fuso 对您的第一条评论: 1 - 如果有多个条目,如果已​​经完成第一个条目的处理,我将从第二个条目重新启动。 2 - 如果我有超过 6 个 home_coool 条目......我从 1.txt 的开头继续。 3 - 我不想仅限于两种研究模式,所以当有home_coool02home_coool03,...,home_coool_some_sufix时,它应该是一个合适的解决方案,但我需要保持一个MWE作为我最初发布了 【参考方案1】:

假设:

只需要担心搜索模式 home_coolhome_cool01(可以添加更多,但需要一些返工;可能使用关联数组来跟踪每个唯一模式的计数) 在继续下一个替换模式之前,将应用两次替换模式 如果我们到达替换模式的末尾,我们会从头开始

示例输入:

$ cat 0.txt
"#sun\t",
"car_snif = house.group_tree(home_cool)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool01)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool01)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool01)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool01)\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool)\t",          # pick up where we left off with 'home_cool'
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool)\t",          # restart from beginning of 0.txt replacment patterns
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree(home_cool)\t",
"machine(shoes_shirt.shop)\t",

一个awk想法:

awk '
NR==FNR        a[NR]=$0; n=NR; next
/home_cool01/  gsub("home_cool01", a[int((i++)%(n*2)/2)+1])
/home_cool/    gsub("home_cool",   a[int((j++)%(n*2)/2)+1])
1
' 1.txt 0.txt

地点:

n==3 - 1.txt 中的行数;所以n*2 == 6 %6 - 将生成 0-5 的输出 (%6/2) - 将输出转换为 0.0, 0.5, 1.0, 1.5, 2.0, 2.5 int(...) - 将输出变成0, 0, 1, 1, 2, 2 +1 - 为我们提供1, 1, 2, 2, 3, 3 的数组索引 注意: 是的,索引有点复杂;我愿意接受简化的建议

这会生成:

"#sun\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, moon, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, moon, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",
"car_snif = house.group_tree((food, apple, sky, cat,blue,)(bag, tortoise,))\t",
"machine(shoes_shirt.shop)\t",

【讨论】:

我正在做测试,现在效果很好,感谢您的解释 你的解释帮助我理解了其他 UNIX 操作,很好的解释.. 我有一个新需求:假设不是用 nth 的 1.txt 文件行替换 0.txt 文件模式中的 nth's,现在我想要 0.txt 和 @ 之间的过程987654342@ 只发生在1.txt 的第二行用作输出之前,此时我将进程重定向到另一个包含要替换的home_cool 字符串的文件。我应该为此发布一个新问题吗? 是的,听起来像是一个新问题,特别是因为我(还)不明白你的提议......所以我假设会有更多轮次的来回......这只会使这个特定的问答变得混乱;是的,如果您打算将另一个文件加入其中,添加逻辑以在替换文件之间跳转……绝对是一个全新的问答 @mark-fuso 是的,我需要用更好的方式表达这一点,我将花一些时间来处理这个问题。

以上是关于查询某个时间段(日期和时间分别用两个DateTimePicker表示,是分开的)之间的记录的sql语句的主要内容,如果未能解决你的问题,请参考以下文章

问: (VFP)在下列有关日期时间型表达式中,语法上不正确的是____. A.DATETIM()-

sql分别用日期月年 分组 group by 分组,datepart函数

每个字符串每出现第 2 次,分别用文件的第 n 行替换两个不同的字符串

MYSQL怎么查询两个时间之间的日期列表

关于数据框中的日期时间与谷歌大查询中的日期时间的问题

随便选择两个城市作为预选旅游目标。实现两个独立的线程分别显示10次城市名,每次显示后休眠一段随机时间(1000ms以内),哪个先显示完毕,就决定去哪个城市。分别用Runnable接口和Thread类实