SQL语句批量查询~
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL语句批量查询~相关的知识,希望对你有一定的参考价值。
数据库中有表[table1]
结构
id[int,标识]
地点名称[varchar(MAX)]
地点里程[varchar(MAX)]
日期[datetime]
记录有:
1, 北路, 600.158, 2008-10-10
2, 北路, 601.528, 2008-10-10
3, 北路, 604.153, 2008-10-10
4, 北路, 602.453, 2008-10-10
5, 南路, 600.958, 2008-10-10
......
假如有1万条数据。
我要查询:2008-10-10至2008-10-17日之间的 “北路” 600.000 到 605.000 之间每隔0.100有多少条记录?
也就是说,地点里程为600.000-600.099之间有多少条记录,600.100-600.199之间有多少条记录。。
至到604.900-604.999,总共要有50多条查询。
特别注意:(地点里程是varchar(MAX)字符类型,是不是还要转换?)
如果优化查询条件?
如果有高人指点200分送上~QQ:3084532
我的地点里程是字符类型。~~如何在SQL语句中转换?
----以下是代码实现
IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[CountTable]') AND type in (N'U'))
DROP TABLE [dbo].[CountTable]
GO
CREATE TABLE [dbo].[CountTable](
[CountNum] [int] NULL
) ON [PRIMARY]
declare @low float
declare @high float
declare @addnum float
declare @define nvarchar(max)
declare @strSql nvarchar(max)
declare @execSql nvarchar(max)
set @low = 600.000
set @high = 605.000
set @addnum = 0.100
while(@low < @high)
begin
set @define = 'declare @CountNum int '
set @strSql = ' select @CountNum = count(*) from table1 where 地点名称=''北路'' and 日期>=''2008-10-10'' and 日期<=''2008-10-17''
and cast(地点里程 as float)>=cast('+''''
+cast(@low as nvarchar(max))+''' as float)'+' and cast(地点里程 as float)<cast('''+cast(@high as nvarchar(max))+''' as float)'
set @execSql = ' insert into CountTable values(@CountNum)'
print @define+@strSql+@execSql
exec (@define+@strSql+@execSql)
set @low = @low + @addnum
end
Go
select * from CountTable 参考技术B 不用这样麻烦!
设计思路:地点里程*10且取整 分组 后就是间隔0.100的分组。注意:地点里程字段必须是有效的数字类型。
select count(id) as 数量,里程分段 from
(select id,地点名称,地点里程,日期,
floor(cast(地点里程 as numeric(12,4))*10) as 里程分段
from table1
where 日期 between '2008-10-10' and '2008-10-17')
group by 里程分段
order by 里程分段 参考技术C SELECT count(*) from table1 where table1.地点名称 = '北路' and table1.日期 >= '2008-10-10'and table1.地点里程 between 600.100 and 600.199;
再编个程序 地点里程每次加0.1执行一次查询,就好了
在mysql中测试通过,地点里程是varchar型,在MySql中也可以直接比较,其他数据库不知道的 参考技术D 感觉charlif 的思路很好,
但就是结果没有将间隔的起始与终止列出来,例如起始 600.100 终止600.199,
SQL语句如下:
declare @low float
declare @high float
declare @addnum float
set @low = 600.000
set @high = 605.000
set @addnum = 0.100
while(@low < @high)
select @low as 起始,@high as 终止,记录数 = count(*) from table1 where 地点名称=''北路'' and 日期>=''2008-10-10'' and 日期<=''2008-10-17''
and cast(地点里程 as float)>=@low and cast(地点里程 as float)<@high
set @low = @low + @addnum
end
如果需要将结果出现在一个结果集中的话,就需要将每个间隔的1条结果插入到一个表中,然后最后从这个表中查询,就和charlif的思路一样,
这个问题算是一个比较经典的应用问题,^_^
呵呵,希望能有帮助,^_^ 第5个回答 2008-10-30 SELECT
CAST(L.里程段 AS DECIMAL(10,3)) 里程段,
COUNT(1) 计数
FROM (SELECT FLOOR(CAST(里程 AS FLOAT) * 10) / 10 里程段 FROM [Test] WHERE 地点名称 = '北路' AND 日期 BETWEEN '2008-10-10' AND '2008-10-17') L
GROUP BY 里程段
一句搞定 无需编程之类的
重新修改了一下 测试通过本回答被提问者采纳
以上是关于SQL语句批量查询~的主要内容,如果未能解决你的问题,请参考以下文章
带参方法的执行:普通方法的查询,可为空方法的查询。批量处理SQL语句。
Oracle数据库中把select语句中查询的记录怎么批量插入数据库中?