51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 6323|回复: 8
打印 上一主题 下一主题

如何测试SQL存储过程?

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2009-3-5 11:52:14 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
查了一些资料,还是不明白存储过程怎样测试,摘了段存储过程,请大家指点下,我也能多学些测试方法。多谢

DELETE FROM HourlyScoringHistory_All
        WHERE DayID = @DayId AND HourNum = @HourNum AND BatchID = @JobID;

        DECLARE @UsersInLiveSegments TABLE
        (
                UserType varchar(1),
                UserCount int
        );

        INSERT INTO @UsersInLiveSegments
                SELECT
                        cosmosResult.UserType,                
                        sum(cosmosResult.[Count])               
                FROM
                        KPI_SegIdUserTypeCountryAggregate cosmosResult INNER JOIN
                        Segment
                                ON cosmosResult.SegmentAuthoringId = Segment.SegmentAuthoringId       
                WHERE Segment.Live = 1
                GROUP BY cosmosResult.UserType;
               
        DECLARE @UsersInTestSegments TABLE
        (
                UserType varchar(1),
                UserCount int
        );

        INSERT INTO @UsersInTestSegments
                SELECT
                        cosmosResult.UserType,                
                        sum(cosmosResult.[Count])               
                FROM
                        KPI_SegIdUserTypeCountryAggregate cosmosResult INNER JOIN
                        Segment
                                ON cosmosResult.SegmentAuthoringId = Segment.SegmentAuthoringId       
                WHERE Segment.Live = 0
                GROUP BY cosmosResult.UserType;

        INSERT INTO HourlyScoringHistory_All
                (
                        DayID,
                        HourNum,
                        BatchID,
                        NumUsersInSegments,
                        NumUsersInLiveSegments,
                        NumUsersInTestSegments,
                        UserType
                )
                SELECT
                        @DayId,
                        @HourNum,
                        @JobID,
                        ISNULL(test.UserCount,0)+ISNULL(live.UserCount,0),
                        ISNULL(live.UserCount,0),
                        ISNULL(test.UserCount,0),
                        ISNULL(test.UserType,live.UserType)
                FROM
                        @UsersInTestSegments test FULL OUTER JOIN @UsersInLiveSegments live
                        ON test.UserType = live.UserType;

[ 本帖最后由 rosepark 于 2009-3-26 11:17 编辑 ]
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2009-4-20 19:57:38 | 只看该作者
支持,同样迷茫中。
前提还是要理解存储过程,我现在除了sql,其他还有待提高。
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2009-5-4 10:09:48 | 只看该作者
我觉得首先要明白存储过程的功能,有哪些参数,可以得到什么样的结果
然后就根据参数传递不同的数据,看得到的结果是否跟预估的一样
回复 支持 反对

使用道具 举报

该用户从未签到

4#
发表于 2009-6-2 11:39:04 | 只看该作者
其实是很简单的,无非就是输入输出的问题,就是符合条件的数据准备!
回复 支持 反对

使用道具 举报

该用户从未签到

5#
发表于 2009-6-10 20:34:21 | 只看该作者
不懂中~~~~~~~~·
回复 支持 反对

使用道具 举报

该用户从未签到

6#
 楼主| 发表于 2009-6-29 15:18:27 | 只看该作者
最近一直在学习存储过程,测试也有了些进展,楼上的兄弟都已经给出提示了。多谢各位!
回复 支持 反对

使用道具 举报

该用户从未签到

7#
发表于 2010-5-16 23:02:24 | 只看该作者
根据此存储过程的功能,制造一些合法的、非法的数据测试存储过程的功能是否实现。
回复 支持 反对

使用道具 举报

该用户从未签到

8#
发表于 2012-7-3 17:29:11 | 只看该作者
至少可以用Exec语句测试一下看这个SP是否正确
回复 支持 反对

使用道具 举报

该用户从未签到

9#
发表于 2012-7-3 17:29:49 | 只看该作者
至少可以用Exec语句测试一下看这个SP是否正确
回复 支持 反对

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-11-22 19:58 , Processed in 0.071958 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表