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

原创 2007年09月21日 10:28:00
摘要: 
本文演示了在 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 use shawl --使用数据库 shawl go create table t --建 t 表  (  --添加字段, 名 id, 并定义为识别字段, 且设为主键  id int identity   constraint pk_t primary key,    --添加字段, 名 title, 长度为 varchar 255, 不能为空, 默认值为空格  title varchar(255) not null default ' ',     --添加字段, 名 content, 长度 varchar 4000, 不能为空, 默认值为空格  content varchar(4000) not null default ' ',    --添加字段, 名 pdate, 不能为空, 默认值为当前日期时间  pdate datetime not null default getdate() ) go  --授权给用户(组)  grant all on t to dbo go
2. 添加记录
2.1 在查询分析器中构造 添加记录的存储过程, 并添加一条新记录
linenum --构造添加记录用的存储过程, 名 dbo.t_insertSproc create proc dbo.t_insertSproc     --定义变量 title 与 content      @title varchar(255),     @content varchar(4000) as  begin     --设置不返回受影响的结果为真     set noCount on     --添加记录     insert t (title,content) values(@title,@content)          --选取并显示刚添加的新记录   select * from t where id=@@identity end  go   --授权给用户(组)   grant exec on dbo.t_insertSproc to dbo go   --添加一条新记录 exec dbo.t_insertSproc   @title='Sproc title',   @content='Sproc content'
2.2 在 ASP 中 使用存储过程 dbo.t_insertSproc 添加数据 到 MSSQL
2.2.1 构造 ADO 连接与关闭函数 createCnn, closeCnn
linenum function createCnn(cnn)     set cnn=createObject("adodb.connection") end function function closeCnn(cnn)         cnn.close     set cnn=nothing end function
2.2.2 使用 cnn 函数和 存储过程 添加数据到 MSSQL
linenum <%     dim title, content     dim sql, rs, cnn     title="this title"     content="the content"     sql="exec dbo.t_insertSproc @title='"&title&"',@content='"&content&"'"     call createCnn(cnn)         cnn.open conn         set rs=cnn.execute(sql)             response.write "新记录已添加, ID为: "&rs("id")             rs.close         set rs=nothing     call closeCnn(cnn) %>
3. 更新记录
3.1 在查询分析器中构造 更新记录用的存储过程, 并更新 ID为1 的记录集
linenum --使用数据库 shawl use shawl go   --构造更新用的存储过程, 名 dbo.t_updateSproc create proc dbo.t_updateSproc     --定义变量 id, title, content     @id int,     @title varchar(255),     @content varchar(4000) as begin     --设置不返回受影响行的结果     set noCount on     --更新内容, 如果变量 id 为空, 则不更新内容     update t set title=@title, content=@content where id=coalesce(@id,0)     --选取并显示被更新的记录集     select * from t where id=@id end go     --授权给用户(组)   grant exec on dbo.t_updateSproc to dbo go   --在查询分析器中执行存储过程, 更新列名 为ID 值=1 的行 exec dbo.t_updateSproc @id=1, @title='update title', @content='update content'
3.2 在 ASP 中使用存储过程执行更新操作
(请检查你有没有创建并引用 2.2.1 的 createCnn 与 closeCnn 函数)
linenum <%     dim id, title, content     dim sql, rs, cnn     id=1     title="update title where id=1"     content="update content"     sql="exec dbo.t_updateSproc @title='"&title&"',@content='"&content&"',@id="&id     call createCnn(cnn)         cnn.open conn         set rs=cnn.execute(sql)             response.write "ID为: "&rs("id")&" 的记录集已更新"             rs.close         set rs=nothing     call closeCnn(cnn) %>
4. 选取记录
4.1 在查询分析器中构造 选取记录集用的存储过程, 并选取 id 为 1 的行
linenum --使用数据库 shawl use shawl go   --构造选取记录用的存储过程, 名 dbo.t_selectSproc create proc dbo.t_selectSproc     --定义变量 id     @id int=null as  begin     --设置不返回受影响行的结果     set noCount on     --选取内容, 如果变量 id 为空, 则选取所有行     select * from t where id=coalesce(@id,id) end go     --授权给用户(组)   grant exec on dbo.t_selectSproc to dbo go   --在查询分析器中执行存储过程 exec dbo.t_selectSproc @id=1
4.2 在 ASP 中使用存储过程, 执行选取数据操作
linenum <%     dim id, num, i     dim sql, rs, cnn     id=1     sql="exec dbo.t_selectSproc @id="&id     'sql="exec dbo.t_selectSproc @id=null"     call createCnn(cnn)         cnn.open conn         set rs=cnn.execute(sql)             with rs                     num=.fields.count-1                 do until .eof                     for i=0 to num                         response.Write rs(i)                         response.Write " "                     next                     response.Write "<br/>"                     .movenext                 loop                     .close                         end with         set rs=nothing     call closeCnn(cnn) %>
5. 删除记录
5.1 在查询分析器中构造 删除记录集用的存储过程, 并删除 title 字段中带 update 字符的行
linenum --使用数据库 shawl use shawl go   --构造删除用的存储过程, 名 dbo.t_deleteSproc create proc dbo.t_deleteSproc      --定义变量 qStr     @qStr varchar(255) as begin     --设置不返回受影响行的结果     set noCount on      --删除数据操作, 使用 patindex 以模糊方式匹配并删除数据     delete t where patindex('%'+lower(@qstr)+'%',lower(title))>0      --返回被删除了几行      select rc=@@rowcount end go      --授权给用户(组)   grant exec on dbo.t_deleteSproc to dbo go   --在查询分析器中执行存储过程 exec dbo.t_deleteSproc @qStr='update'
5.2 在 ASP 中使用存储过程, 执行删除数据操作
linenum <%     dim qStr     dim sql, rs, cnn     qStr="sproc"     sql="exec dbo.t_deleteSproc @qStr="&qStr     call createCnn(cnn)         cnn.open conn         set rs=cnn.execute(sql)             response.write "共有 "&rs("rc")&" 行被删除"             rs.close         set rs=nothing     call closeCnn(cnn) %>  

SQLServer千万数量级分页公共存储过程

转自:http://blog.csdn.net/tem168/article/details/6427123 SQLServer千万数量级分页公共存储过程   通用的数据库分页存...
  • chelen_jak
  • chelen_jak
  • 2014年12月11日 21:24
  • 3101

sqlite3的基本操作

转自:http://blog.chinaunix.net/uid-26833883-id-3239313.html 一、数据库基本概念 A.数据(Data) ...
  • WitsMakeMen
  • WitsMakeMen
  • 2014年02月24日 15:52
  • 6162

JSON数据操作

 JSON (JavaScript ObjectNotation)JS对象记号,是JavaScript中一个标准子集,所以用JavaScript平台处理JSON是最合适的。 JSON有...
  • fullStackChenZF
  • fullStackChenZF
  • 2017年03月15日 11:54
  • 944

[置顶] Oracle PL/SQL中编写空操作的存储过程

原创文章,转载请注明作者:黄文海 来源:http://viscent.iteye.com,同步发布在:http://blog.viscenthuang.info/2012/10/oracle-plsq...
  • viscent_huang
  • viscent_huang
  • 2015年11月18日 11:20
  • 798

在asp中调用sql server的存储过程方法

在asp中调用sql server的存储过程可以加快程序运行速度   1.调用存储过程的一般方法   先假设在sql server中有一存储过程dt_users:   CREATE PROCED...
  • sscrazy
  • sscrazy
  • 2014年11月13日 16:01
  • 566

SQL 语法之“增”、“删”、“改”、“查”

/* 四、查 1.普通查询 语法:select from [where ] [order by [asc或desc]] */ /*    1).查询所有数据行和列     ...
  • Carvin_Zh
  • Carvin_Zh
  • 2015年07月29日 15:19
  • 1455

mysql存储过程 游标 查询结果循环

Mysql的存储过程是从版本5才开始支持的,所以目前一般使用的都可以用到存储过程。今天分享下自己对于Mysql存储过程的认识与了解。 一些简单的调用以及语法规则这里就不在赘述,网上有许多例子。这里主...
  • cao478208248
  • cao478208248
  • 2014年05月30日 09:38
  • 4391

MSSQL中存储过程的可选参数的定义和使用

可选参数的存在,可以极大的降低代码的重复冗余。在数据库开发中,也是如此。现在针对MSSQL中存储过程的可选参数的定义和使用进行基本的介绍,留作备忘。...
  • hjnth
  • hjnth
  • 2016年05月08日 10:42
  • 2588

如果要使用复杂功能查询,请使用存储过程

不要使用DISTINCT和UNION语句 尽可能不要在T-SQL查询语句中使用DISTINCT和UNION语句。这两个关键词会极大地拖累查询性能,因为它们需要对查询结果执行排序操作来识别并去除重...
  • u010745238
  • u010745238
  • 2015年01月18日 23:20
  • 896

sqlserver 练习题目(存储过程:循环erp数据表,生成另一个表数据)

– ##表结构 ### use test_db;CREATE TABLE [dbo].[GYGDFT]( [任务单号] varchar NOT NULL, [任务序号] [int] NULL,...
  • u010503822
  • u010503822
  • 2016年10月02日 16:46
  • 635
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ASP + mssql 与 查询分析器 之 使用存储过程 建,添,更,选,删 基本数据操作
举报原因:
原因补充:

(最多只允许输入30个字)