科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道应用软件ASP + mssql 与 查询分析器 之 使用存储过程 建,添,更,选,删 基本数据操作 By shawl.qiu

ASP + mssql 与 查询分析器 之 使用存储过程 建,添,更,选,删 基本数据操作 By shawl.qiu

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文演示了在 MSSQL查询分析器中使用存储过程和在 ASP使用存储过程 对 MSSQL 的基本数据操作, 包括建表, 添加,更新,选取,删除记录. 说明: 建=建表 / create table 添=添加记录 /

作者:btbtd 来源: CSDN 2008年3月24日

关键字: 操作 数据 存储 Web开发 软件

  • 评论
  • 分享微博
  • 分享邮件

ASP + mssql 与 查询分析器 之 使用存储过程 建,添,更,选,删 基本数据操作 By shawl.qiu


摘要: 
本文演示了在 MSSQL查询分析器中使用存储过程和在 ASP使用存储过程 对 MSSQL 的基本数据操作, 包括建表, 添加,更新,选取,删除记录.

说明: 
建=建表 / create table
添=添加记录 / insert
更=更新记录 / update
选=选取记录 / select
删=删除记录 / delete

目录:
1. 在查询分析器中建表, 名 t, 并授权给用户(组)

2. 添加记录
2.1 在查询分析器中构造 添加记录的存储过程, 并添加一条新记录
2.2 在 ASP 中 使用存储过程 dbo.t_insertSproc 添加数据 到 MSSQL
2.2.1 构造 ADO 连接与关闭函数 createCnn, closeCnn
2.2.2 使用 cnn 函数和 存储过程 添加数据到 MSSQL

3. 更新记录
3.1 在查询分析器中构造 更新记录用的存储过程, 并更新 ID为1 的记录集
3.2 在 ASP 中使用存储过程执行更新操作
(请检查你有没有创建并引用 2.2.1 的 createCnn 与 closeCnn 函数)

4. 选取记录
4.1 在查询分析器中构造 选取记录集用的存储过程, 并选取 id 为 1 的行
4.2 在 ASP 中使用存储过程, 执行选取数据操作

5. 删除记录
5.1 在查询分析器中构造 删除记录集用的存储过程, 并删除 title 字段中带 update 字符的行
5.2 在 ASP 中使用存储过程, 执行删除数据操作

shawl.qiu
2006-8-28
 http://blog.csdn.net/btbtd

1. 在查询分析器中建表, 名 t, 并授权给用户(组)
    linenum
  1. use shawl --使用数据库 shawl
  2. go
  3. create table t --建 t 表 
  4. (
  5.  --添加字段, 名 id, 并定义为识别字段, 且设为主键
  6.  id int identity 
  7.  constraint pk_t primary key,
  8.  --添加字段, 名 title, 长度为 varchar 255, 不能为空, 默认值为空格
  9.  title varchar(255) not null default ' ', 
  10.  --添加字段, 名 content, 长度 varchar 4000, 不能为空, 默认值为空格
  11.  content varchar(4000) not null default ' ',
  12.  --添加字段, 名 pdate, 不能为空, 默认值为当前日期时间
  13.  pdate datetime not null default getdate()
  14. )
  15. go
  16.  --授权给用户(组)
  17.  grant all on t to dbo
  18. go

2. 添加记录
2.1 在查询分析器中构造 添加记录的存储过程, 并添加一条新记录
    linenum
  1. --构造添加记录用的存储过程, 名 dbo.t_insertSproc
  2. create proc dbo.t_insertSproc
  3.   --定义变量 title 与 content 
  4.     @title varchar(255),
  5.     @content varchar(4000)
  6. as 
  7. begin
  8.   --设置不返回受影响的结果为真
  9.     set noCount on
  10.   --添加记录
  11.     insert t (title,content) values(@title,@content)
  12.     
  13.     --选取并显示刚添加的新记录
  14.   select * from t where id=@@identity
  15. end 
  16. go
  17.   --授权给用户(组)
  18.   grant exec on dbo.t_insertSproc to dbo
  19. go
  20. --添加一条新记录
  21. exec dbo.t_insertSproc
  22.   @title='Sproc title',
  23.   @content='Sproc content'

2.2 在 ASP 中 使用存储过程 dbo.t_insertSproc 添加数据 到 MSSQL
2.2.1 构造 ADO 连接与关闭函数 createCnn, closeCnn
    linenum
  1. function createCnn(cnn)
  2.     set cnn=createObject("adodb.connection")
  3. end function
  4. function closeCnn(cnn)
  5.         cnn.close
  6.     set cnn=nothing
  7. end function

2.2.2 使用 cnn 函数和 存储过程 添加数据到 MSSQL
    linenum
  1. <%
  2.     dim title, content
  3.     dim sql, rs, cnn
  4.     title="this title"
  5.     content="the content"
  6.     sql="exec dbo.t_insertSproc @title='"&title&"',@content='"&content&"'"
  7.     call createCnn(cnn)
  8.         cnn.open conn
  9.         set rs=cnn.execute(sql)
  10.             response.write "新记录已添加, ID为: "&rs("id")
  11.             rs.close
  12.         set rs=nothing
  13.     call closeCnn(cnn)
  14. %>

3. 更新记录
3.1 在查询分析器中构造 更新记录用的存储过程, 并更新 ID为1 的记录集
    linenum
  1. --使用数据库 shawl
  2. use shawl
  3. go
  4. --构造更新用的存储过程, 名 dbo.t_updateSproc
  5. create proc dbo.t_updateSproc
  6.   --定义变量 id, title, content
  7.     @id int,
  8.     @title varchar(255),
  9.     @content varchar(4000)
  10. as
  11. begin
  12.   --设置不返回受影响行的结果
  13.     set noCount on
  14.   --更新内容, 如果变量 id 为空, 则不更新内容
  15.     update t set title=@title, content=@content where id=coalesce(@id,0)
  16.   --选取并显示被更新的记录集
  17.     select * from t where id=@id
  18. end
  19. go
  20.   --授权给用户(组)
  21.   grant exec on dbo.t_updateSproc to dbo
  22. go
  23. --在查询分析器中执行存储过程, 更新列名 为ID 值=1 的行
  24. exec dbo.t_updateSproc @id=1, @title='update title', @content='update content'

3.2 在 ASP 中使用存储过程执行更新操作
(请检查你有没有创建并引用 2.2.1 的 createCnn 与 closeCnn 函数)
    linenum
  1. <%
  2.     dim id, title, content
  3.     dim sql, rs, cnn
  4.     id=1
  5.     title="update title where id=1"
  6.     content="update content"
  7.     sql="exec dbo.t_updateSproc @title='"&title&"',@content='"&content&"',@id="&id
  8.     call createCnn(cnn)
  9.         cnn.open conn
  10.         set rs=cnn.execute(sql)
  11.             response.write "ID为: "&rs("id")&" 的记录集已更新"
  12.             rs.close
  13.         set rs=nothing
  14.     call closeCnn(cnn)
  15. %>

4. 选取记录
4.1 在查询分析器中构造 选取记录集用的存储过程, 并选取 id 为 1 的行
    linenum
  1. --使用数据库 shawl
  2. use shawl
  3. go
  4. --构造选取记录用的存储过程, 名 dbo.t_selectSproc
  5. create proc dbo.t_selectSproc
  6.   --定义变量 id
  7.     @id int=null
  8. as 
  9. begin
  10.   --设置不返回受影响行的结果
  11.     set noCount on
  12.   --选取内容, 如果变量 id 为空, 则选取所有行
  13.     select * from t where id=coalesce(@id,id)
  14. end
  15. go
  16.   --授权给用户(组)
  17.   grant exec on dbo.t_selectSproc to dbo
  18. go
  19. --在查询分析器中执行存储过程
  20. exec dbo.t_selectSproc @id=1

4.2 在 ASP 中使用存储过程, 执行选取数据操作
    linenum
  1. <%
  2.     dim id, num, i
  3.     dim sql, rs, cnn
  4.     id=1
  5.     sql="exec dbo.t_selectSproc @id="&id
  6.     'sql="exec dbo.t_selectSproc @id=null"
  7.     call createCnn(cnn)
  8.         cnn.open conn
  9.         set rs=cnn.execute(sql)
  10.             with rs
  11.                     num=.fields.count-1
  12.                 do until .eof
  13.                     for i=0 to num
  14.                         response.Write rs(i)
  15.                         response.Write " "
  16.                     next
  17.                     response.Write "<br/>"
  18.                     .movenext
  19.                 loop    
  20.                 .close            
  21.             end with
  22.         set rs=nothing
  23.     call closeCnn(cnn)
  24. %>

5. 删除记录
5.1 在查询分析器中构造 删除记录集用的存储过程, 并删除 title 字段中带 update 字符的行
    linenum
  1. --使用数据库 shawl
  2. use shawl
  3. go
  4. --构造删除用的存储过程, 名 dbo.t_deleteSproc
  5. create proc dbo.t_deleteSproc
  6.   
  7.   --定义变量 qStr
  8.     @qStr varchar(255)
  9. as
  10. begin
  11.   --设置不返回受影响行的结果
  12.     set noCount on
  13.   
  14.   --删除数据操作, 使用 patindex 以模糊方式匹配并删除数据
  15.     delete t where patindex('%'+lower(@qstr)+'%',lower(title))>0
  16.   
  17.   --返回被删除了几行 
  18.     select rc=@@rowcount
  19. end
  20. go
  21.   
  22.   --授权给用户(组)
  23.   grant exec on dbo.t_deleteSproc to dbo
  24. go
  25. --在查询分析器中执行存储过程
  26. exec dbo.t_deleteSproc @qStr='update'

5.2 在 ASP 中使用存储过程, 执行删除数据操作
    linenum
  1. <%
  2.     dim qStr
  3.     dim sql, rs, cnn
  4.     qStr="sproc"
  5.     sql="exec dbo.t_deleteSproc @qStr="&qStr
  6.     call createCnn(cnn)
  7.         cnn.open conn
  8.         set rs=cnn.execute(sql)
  9.             response.write "共有 "&rs("rc")&" 行被删除"
  10.             rs.close
  11.         set rs=nothing
  12.     call closeCnn(cnn)
  13. %>
    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章