1. sqlserver 存储过程,执行有错误。消息 207,级别 16,状态 1,过程 proc_View_App_and_Arr,第 26 行 列名
你的临时表里的列明显比你插入数据的列少。。。。。。
2. 数据库问题消息 207,级别 16,状态 1,第 3 行 列名 '0001' 无效。
要用英文的单引号来代表字符,不能用双引号
3. sql中 消息 8102,级别 16,状态 1,第 1 行 是什么错误?
错误 8102
严重级别 16
消息正文
无法更新标识列 ''%1!''。
解释
明确试图在 UPDATE 语句的 SET 部分中更改标识列的值。只能在 UPDATE 语句的 WHERE 子句中使用标识列。
对策
不允许更新标识列。若要更新标识列,可以使用以下方法:
若要重新指派所有标识值,请大容量复制出数据,然后除去并重建具有正确种子和增量值的表。然后将数据大容量复制回到新建的表中。当 bcp 插入值时,将适当地增加这些值并重新分发标识值。也可以使用 INSERT INTO 和 sp_rename 命令完成同一操作。
若要重新指派单个行,必须删除该行,然后使用 SET IDENTITY_INSERT tblName ON 子句将其插入。
4. SQL数据库错误消息消息 208,级别 16,状态 1,第 2 行
这个库可能没选对,下拉选择一下(我的问题就是这样婶的)
5. 用存储过程的方式实现修改表列的记录中遇到的“语法错误”问题
看了前人的回复,你的执行存储过程最后运行的sql语句为
update babies2 set Birthplace = '22030301' where Attacher=吕布
你这样看你的sql语句 你应该就知道出错哪里了,你的Attacher=吕布 其中的Attacher应该是字符串格式的 你给赋值的 吕布 并非是字符串。你执行此语句肯定是出错的
6. SQL里存储过程分页问题!急!急!
CREATE PROCEDURE [Zhzuo_GetItemsPage]
@PageIndex INT, /*@PageIndex从计数,0为第一页*/
@PageSize INT, /*页面大小*/
@RecordCount INT OUT, /*总记录数*/
@PageCount INT OUT /*页数*/
AS
/*获取记录数*/
SELECT @RecordCount = COUNT(*) FROM Production.Product
/*计算页面数据*/
SET @PageCount = CEILING(@RecordCount * 1.0 / @PageSize)
/*TOP记录数*/
DECLARE @TOPCOUNT INT
SET @TOPCOUNT = @RecordCount - @PageSize * @PageIndex
DECLARE @SQLSTR NVARCHAR(1000)
IF @PageIndex = 0 OR @PageCount <= 1
BEGIN
SET @SQLSTR =N'SELECT TOP '+STR(@PageSize)+
'ProductID,Name FROM Production.Product ORDER BY ProductID DESC'
END
ELSE
BEGIN
IF @PageIndex = @PageCount - 1
BEGIN
SET @SQLSTR =N'SELECT * FROM ( SELECT TOP ' + STR(@TOPCOUNT) +
'ProductID,Name FROM Production.Product ORDER BY ProductID ASC) T ORDER BY ProductID DESC'
END
ELSE
BEGIN
SET @SQLSTR =N' SELECT TOP '+STR(@PageSize)+'* FROM (SELECT TOP ' + STR(@TOPCOUNT) +
'ProductID,Name FROM Production.Product ORDER BY ProductID ASC) T ORDER BY ProductID DESC'
END
END
/*执行*/
EXEC (@SQLSTR)
以上存储过程对页数进行判断,如果是第一页或最后一页,进行特殊处理。其他情况使用2次TOP翻转。其中排序条件为ProductID倒序。最后通过EXECUTE执行SQL字符串拼串。
2.SQL SERVER 2005中的TOP分页
CREATE PROCEDURE [dbo].[Zhzuo_GetItemsPage2005TOP]
@PageIndex INT,
@PageSize INT,
@RecordCount INT OUT,
@PageCount INT OUT
AS
/*获取记录数*/
SELECT @RecordCount = COUNT(*) FROM Production.Product
/*计算页面数据*/
SET @PageCount = CEILING(@RecordCount * 1.0 / @PageSize)
/*TOP记录数*/
DECLARE @TOPCOUNT INT
SET @TOPCOUNT = @RecordCount - @PageSize * @PageIndex
/*基于SQL SERVER 2005 */
IF @PageIndex = 0 OR @PageCount <= 1
BEGIN
SELECT TOP(@PageSize) ProductID,Name FROM Production.Product ORDER BY ProductID DESC
END
ELSE
BEGIN
IF @PageIndex = @PageCount - 1
BEGIN
SELECT * FROM ( SELECT TOP(@TOPCOUNT) ProductID,Name FROM Production.Product ORDER BY ProductID ASC) T
ORDER BY ProductID DESC
END
ELSE
BEGIN
SELECT TOP(@PageSize) * FROM (SELECT TOP(@TOPCOUNT) ProductID,Name FROM Production.Product ORDER BY ProductID ASC) T
ORDER BY ProductID DESC
END
END
以上存储过程是使用2005的TOP (表达式) 新功能,避免了字符串拼串,使结构化查询语言变得简洁。实现的为同样的功能。
3.SQL SERVER 2005中的新分页
CREATE PROCEDURE [dbo].[Zhzuo_GetItemsPage2005]
@PageIndex INT,
@PageSize INT,
@RecordCount INT OUT,
@PageCount INT OUT
AS
/*获取记录数*/
SELECT @RecordCount = COUNT(*) FROM Production.Product
/*计算页面数据*/
SET @PageCount = CEILING(@RecordCount * 1.0 / @PageSize)
/* 基于SQL SERVER 2005 */
SELECT SerialNumber,ProductID,Name FROM
(SELECT ProductID,Name,ROW_NUMBER() OVER (ORDER BY ProductID DESC) AS SerialNumber FROM Production.Product ) AS T
WHERE T.SerialNumber > (@PageIndex * @PageSize) and T.SerialNumber <= ((@PageIndex+1) * @PageSize)
第三个存储过程使用2005下新的功能,实现的分页存储过程功能更加简单明了,而且更加容易理解。注意这里的ProductID为主键,根据ProductID进行排序生成ROW_NUMBER,通过ROW_NUMBER来确定具体的页数。
通过对三个分页存储过程的比较,可见SQL SERVER 的TSQL 语言对分页功能的支持进步不少。使分页实现趋向于简单化。
7. SQL存储过程中查询视图数据
那么是视图View_StuInfo中不存在这些字段了, 请先检查一下视图的定义, 都有哪些字段.
还有一点, 参数名最好不要使用中文.
8. sql存储过程--关于参数传递
列名 'admin' 无效 要与你定义的存储过程的名一样才行。