【求助】把数据添加到临时表出错

gufengsheng 2005-05-06 04:19:49
代码如下:
declare @strSQL varchar(100)
CREATE TABLE #tempTable(ID int identity(1,1),NID int)
SET @strSQL = 'INSERT INTO #tempTable(NID) SELECT TOP 20 fID FROM [tOA] SELECT T1.*,T2.* FROM [tOA] AS T1, #tempTable AS T2 WHERE T1.fID = T2.NID AND T2.ID > 0 AND T2.ID <= 10 ORDER BY T2.ID DROP TABLE #tempTable'
EXEC (@strSQL)

如果是这样就不会出错:
CREATE TABLE #tempTable(ID int identity(1,1),NID int)
INSERT INTO #tempTable(NID) SELECT TOP 20 fID FROM [tOA] SELECT T1.*,T2.* FROM [tOA] AS T1, #tempTable AS T2 WHERE T1.fID = T2.NID AND T2.ID > 0 AND T2.ID <= 10 ORDER BY T2.ID DROP TABLE #tempTable
有谁知道为什么吗?
...全文
237 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
gufengsheng 2005-05-06
  • 打赏
  • 举报
回复
继续顶。。。。。。。。。。。。
gufengsheng 2005-05-06
  • 打赏
  • 举报
回复
不行的,我看你没改动啊
wudan8057 2005-05-06
  • 打赏
  • 举报
回复
--试一试
declare @s_sql varchar(4000)

set @s_sql = ''
set @s_sql = @s_sql + 'CREATE TABLE #tempTable(ID int identity(1,1),NID int)'
set @s_sql = @s_sql + 'INSERT INTO #tempTable(NID) SELECT TOP ' + str(@PageIndex*@PageSize) + ' fID FROM [' + @tblName + ']'

IF (@strWhere != '')
SET @s_sql = @s_sql + ' WHERE ' + @strWhere + @strOrder
ELSE
SET @s_sql = @s_sql + @strOrder

--以下代码赋予了@strSQL以真正执行的SQL代码
SET @s_sql = @s_sql + ' SELECT ' + @strGetFields + ', T2.ID FROM [' + @tblName + '] T1, #tempTable T2 WHERE T1.fID = T2.NID AND T2.ID > ' + @PageLowerBound + ' AND T2.ID <= ' + @PageUpperBound + ' ORDER BY T2.ID DROP TABLE #tempTable'
EXEC (@strSQL)
gufengsheng 2005-05-06
  • 打赏
  • 举报
回复
楼上的,不能用SELECT INTO的,因为我的fID字段是自动编号字段。
wudan8057 2005-05-06
  • 打赏
  • 举报
回复
或者:
SELECT TOP 20
identity(int,1,1) id,
fID
INTO #tempTable
FROM [tOA]

SELECT T1.*,T2.*
FROM [tOA] AS T1, #tempTable AS T2
WHERE T1.fID = T2.NID AND
T2.ID > 0 AND
T2.ID <= 10
ORDER BY T2.ID

DROP TABLE #tempTable
gufengsheng 2005-05-06
  • 打赏
  • 举报
回复
楼上的,还是有错啊,说什么SE附近有错误。
我的全部SQL如下(人家的代码修改的,是把数据绑定到DataGrid的):
CREATE PROCEDURE spNavigators
(
@tblName varchar(15),
@strGetFields varchar(100) = '*',
@PageSize int = 20,
@PageIndex int = 1,
@doCount bit = 0,
@strOrderBy varchar(50) = '',
@strWhere varchar(100) = '',
@RecordCount int output
)
AS
-- 主语句
DECLARE @strSQL varchar(400)
SET @strSQL = ''
-- 排序变量
DECLARE @strOrder varchar(70)
SET @strOrder = ''

SET @RecordCount = 0
--如果@doCount传递过来的不是0,就执行总数统计
IF (@doCount != 0)
BEGIN
DECLARE @sWhere varchar(120)

SET @sWhere = ''
IF (@strWhere != '')
SET @sWhere = ' WHERE ' + @strWhere

SET @strSQL = 'if exists (select * from dbo.sysobjects where id = object_id(''[dbo].[tmpTable]'') and OBJECTPROPERTY(id, ''IsUserTable'') = 1) '
SET @strSQL = @strSQL + ' UPDATE tmpTable SET Total = (SELECT COUNT(*) FROM [' + @tblName + '] ' + @sWhere + ') '
SET @strSQL = @strSQL + ' ELSE SELECT COUNT(*) AS Total INTO tmpTable FROM [' + @tblName + '] ' + @sWhere

EXEC (@strSQL)

SELECT @RecordCount=Total FROM tmpTable

--删除总数统计临时表
EXEC ('DROP TABLE tmpTable')
END

PRINT @RecordCount

--排序字段信息
IF (@strOrderBy != '')
SET @strOrder = ' ORDER BY ' + @strOrderBy

--如果是第一页就执行以上代码,这样会加快执行速度
IF (@PageIndex = 1)
BEGIN
IF (@strWhere != '')
SET @strSQL = 'SELECT TOP ' + str(@PageSize) + ' ' + @strGetFields + ' FROM [' + @tblName + '] WHERE ' + @strWhere + @strOrder
ELSE
SET @strSQL = 'SELECT TOP ' + str(@PageSize) + ' ' + @strGetFields + ' FROM ['+ @tblName + '] '+ @strOrder
END
ELSE
BEGIN
--为搜索表建立自动编号 保存到临时表中
DECLARE @PageLowerBound int /* 数组下标 */
DECLARE @PageUpperBound int /* 数组上标 */
SET @PageLowerBound=(@PageIndex-1)*@PageSize
SET @PageUpperBound=@PageLowerBound+@PageSize
CREATE TABLE #tempTable(ID int identity(1,1),NID int)

SET @strSQL = 'INSERT INTO #tempTable(NID) SELECT TOP ' + str(@PageIndex*@PageSize) + ' fID FROM [' + @tblName + ']'
IF (@strWhere != '')
SET @strSQL = @strSQL + ' WHERE ' + @strWhere + @strOrder
ELSE
SET @strSQL = @strSQL + @strOrder

--以下代码赋予了@strSQL以真正执行的SQL代码
SET @strSQL = @strSQL + ' SELECT ' + @strGetFields + ', T2.ID FROM [' + @tblName + '] T1, #tempTable T2 WHERE T1.fID = T2.NID AND T2.ID > ' + @PageLowerBound + ' AND T2.ID <= ' + @PageUpperBound + ' ORDER BY T2.ID DROP TABLE #tempTable'
END

PRINT @strSQL

EXEC (@strSQL)


GO


wudan8057 2005-05-06
  • 打赏
  • 举报
回复
改为:
declare @strSQL varchar(100)
CREATE TABLE #tempTable(ID int identity(1,1),NID int)
SET @strSQL = 'CREATE TABLE #tempTable(ID int identity(1,1),NID int)
INSERT INTO #tempTable(NID) SELECT TOP 20 fID FROM [tOA]
SELECT T1.*,T2.*
FROM [tOA] AS T1, #tempTable AS T2
WHERE T1.fID = T2.NID AND
T2.ID > 0 AND
T2.ID <= 10 ORDER BY T2.ID
DROP TABLE #tempTable'
EXEC (@strSQL)
gufengsheng 2005-05-06
  • 打赏
  • 举报
回复
为什么不用Select Into,是因为我的原始表中存在自动编号字段。
gufengsheng 2005-05-06
  • 打赏
  • 举报
回复
还有就是我为什么要用参数是因为我的@strSQL是动态的。
请先阅读帮助文档:http://ismyway.com/help [2009.1.1] Ver 3.2.26 ※如果安装提示证书过期或无法安装,请在手机上将时间改为2008.8.8,安装设置完成后再将日期改回即可!※ 增加天语的按键映射 增加三星的背景灯控制功能(该功能未在真机上测试过) 删除图片浏览中的部分功能,由于这部分功能需要较大的内存,导致在大部分手机上无法完成,同时也引起背景图片无法设置成功 触摸屏用户可以不再受滚动条限制,在屏幕上任意地方都可以进行拖动 选择键盘映射为其它时无法再次更改的BUG 用户输入的颜色值无法保存的BUG 修正英文单词分词时会多添加一个空行的BUG 繁体语言措词上的修正 阅读设置中增加一个“文件缓存”选项,默认情况下是开启的,在NOKIA手机上会提高UMD等文件的表现,但由于测试并不充足,如果程序经常在阅读时出错,请关闭该选项(其它手机是否开启该选项并无明显的影响) 修正编辑文件后无法保存的BUG [2008.10.27] Ver 3.2.24 ※如果安装提示证书过期或无法安装,请在手机上将时间改为2008.8.8,安装设置完成后再将日期改回即可!※ 改进的颜色选择方式 允许用户重新选择键盘映射 HTML阅读时的错误 进一步完善编辑功能(仍有少许BUG,请继续反馈,谢谢) 新建文件后自动跳转到编辑中 改进的文件操作方式,速度轻微提升 UMD速度明显提升,并且减少内存占用,特别是在NOKIA手机上,表现提升超过600% 改进的输入框模式,以使得能适应更多的手机如天语等 [2008.10.21] Ver 3.2.23 为了提高运行效率,以下功能在LITE上将被取消(自定义欢迎页问候语;欢迎页背景图) 取消了JAR的支持,提高运行效率 修正打开大ZIP文件时的内存溢出错误 ·修正:  自动滚屏到末尾时,滚屏功能将停止 [2008.10.4] Ver 3.2.22 暂时删除了播放功能及网络相关的功能,由于以上两项功能一直没有能稳定下来,故暂时删除 增强了ZIP功能,支持带文件夹结构的ZIP/JAR文件 (对于大部分JAR电子书都,可以从文件管理器中找到非.class结尾的文件,并且选择打开为UNICODE/TXT阅读) (对于NOKIA手机及其它部分手机,由于安全策略的限制,在Anyview的文件管理器中无法查看后缀为.jar的文件) 自定义问候语(系统路径下dictum.rc文件,格式参见jar包中的dictum.rc文件,保存时使用UTF-8编码,可写条目为0~9/a~z/A~Z,置空时表示不显示问候语) ·修正:  0键在各偏好中切换时亮度混乱的问题  部分手机上无法新建文件夹 [2008.9.11] Ver 3.2.21 修正动画参数无法保存的BUG 动画效果不再对阅读翻页有作用 [2008.8.29] Ver 3.2.21 可将正在阅读的内容通过短信与好友分享 增加一种新的滚屏方式:波浪,同时,阅读时3键不再使用默认的像素滚屏,而会使用最后一次使用的滚屏方式 任何可用的外置字库都可以作为内置字库存在,在jar包中存在dot.font会被当为内置字库加载 加快大文件的打开速度,特别是对于NOKIA手机,S60上,打开20M文件,97%左右的位置不超过15秒 允许用户打开动画效果 ·M600/P990/P1/W950  修正键盘映射时“内存不足”的BUG ·E680/A780  选中后台播放后无法启动的BUG [2008.7.30] Ver 3.2.20 调整部分索爱手机上背景灯控制的逻辑 修正看图片时按0键出错的BUG 旋转屏幕引起的字外出 打开LRC最后出错 阅读到尾部弹出“上一个/下一个”窗口中的文件名过长不刷新的问题 偏好切换时亮度混乱的问题 在NOKIA上,当系统路径设置为根目录是无法启动的BUG E398上可以开关键盘灯 UIQ系统在退出时可以保持亮度 索爱上按“返回”键后导致阅读出现白屏的BUG 阅读时切换屏幕方向导致字体超出屏幕的BUG 欢迎屏幕上的日期使用中文显示 如果使用触屏手机,跳转改为进度条模式,以方便触屏操作 系统路径下如果存在bg.png文件,则会作为欢迎界面的背景图片显示(右下角) 减少跳转及翻页中出现乱码的机率 提高阅读时绘图效率,滚屏效率同样提高 播放时,暂停会导致声音爆至最大的BUG 内置“忘记月亮”制作的两款主题《典雅红》《黑橙》,并且更换主题不再要求退出 文件管理器中支持“剪切”功能 文件管理器中新增转换UMD为TXT的功能(解开操作,解开2无效!) 增加了编辑功能(尽管没有限制文件大小,但请别编辑过大的文件,另外,为了提高速度,不进行全文排版,有时候表现可能会有些不习惯),以后会进一步完善 启动时,会自动识别NOKIA、SONYER

27,582

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧