34,590
社区成员
发帖
与我相关
我的任务
分享
ALTER PROCEDURE [dbo].[tuc_process]
@truckName varchar(16),--卡车的名称
@startTime varchar(20), --开始时间
@endTime varchar(20), --结束时间
@timeLimit int, --时间限制
@retuleFlag int output --结果返回判定 0 有车无key, 1 无数据 2 有数据
AS
BEGIN
SET NOCOUNT ON
--临时表
if object_id('tempdb..##tempTruck') > 0 drop table ##tempTruck
--卡车gps里的key
declare @srcTarget varchar(16)
select @srcTarget = SIMID from VehileTable v where v.VehileMark = @truckName
--卡车的key不存在
if @srcTarget is not null
BEGIN
--卡车的记录
SELECT
[SrcTarget],
[GPS_UTC]into ##tempTruck
FROM Track t
where t.srcTarget = @srcTarget and t.GPS_UTC >= @startTime and t.GPS_UTC <= @endTime
if exists(select top 1 SrcTarget from ##tempTruck)
BEGIN
insert into ##tempTruck values(@srcTarget, @startTime)
insert into ##tempTruck values(@srcTarget, @endTime)
select a.currentDate, a.afterDate, datediff(s,a.currentDate,a.afterDate) as timeLimit from (select
t.SrcTarget,
t.GPS_UTC as currentDate,
isnull((select top 1 GPS_UTC from ##tempTruck where SrcTarget = t.SrcTarget and GPS_UTC>t.GPS_UTC order by GPS_UTC ), t.GPS_UTC) as afterDate
from ##tempTruck t) a where datediff(s,a.currentDate,a.afterDate) > @timeLimit
--drop table ##tempTruck
set @retuleFlag = 2
END
else
set @retuleFlag = 1
END
else
set @retuleFlag = 0
SET NOCOUNT OFF
END
exec('select * into #T from test ; select * from #T')
/*序号 value
----------- -----------
1 1
2 2
3 3
4 4
5 5*/
临时表有两种类型:
本地临时表
以一个井号 (#) 开头的那些表名。只有在创建本地临时表的连接上才能看到这些表。
全局临时表
以两个井号 (##) 开头的那些表名。在所有连接上都能看到全局临时表。如果在创建全局临时表的连接断开前没有显式地除去这些表,那么只要所有其它任务停止引用它们,这些表即被除去。当创建全局临时表的连接断开后,新的任务不能再引用它们。当前的语句一执行完,任务与表之间的关联即被除去;因此通常情况下,只要创建全局临时表的连接断开,全局临时表即被除去。
create proc p1
as
select * into # from sysobjects
select * from #
结果一样
create proc p1
as
select * from sysobjects
exec p1
sysobjects 1 S 1 25 -536870909 96 0 0 2000-08-06 01:29:12.717
sysindexes 2 S 1 29 -536870907 32 0 0 2000-08-06 01:29:12.717
syscolumns 3 S 1 32 -536870909 80 0 0 2000-08-06 01:29:12.717
systypes 4 S 1 20 -536870909 80 0 0 2000-08-06 01:29:12.717
syscomments 6 S 1 10 -536870911 48 0 0 2000-08-06 01:29:12.717
…………