仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1109|回复: 8
打印 上一主题 下一主题

[学习教程] MSSQL网页设计摹拟字符串处置函数 stuff 的存储历程,...

[复制链接]
若天明 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 22:24:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
有了数据以后,我们就要想一个比较统一的方法来闪回。上面我们说了对于DML操作,可以通过反向执行所有逆操作来实现,对于语句里面的DDL,只能直接跳过。原因是一个DDL不一定有直接的逆操作。存储历程|函数|字符串ifexists(select*fromdbo.sysobjectswhereid=object_id(N[dbo].[p_stuff])andOBJECTPROPERTY(id,NIsProcedure)=1)
dropprocedure[dbo].[p_stuff]
GO/*--Ntext字段处置
摹拟字符串处置函数stuff
完成表中ntext字段的stuff处置
注重,表中必要有列名为:id的主键(或标识字段),数据范例为int
假如没有这个主键字段,大概是其他范例,则对应的必要修正存储历程
--邹建2004.07--*/
/*--挪用示例
--测试数据
createtabletb(idintidentity(1,1),contentntext)
inserttbselecta;sd
unionallselecta;sdfkjas2qasdfdfsg45yhjhdfg45645a
--挪用存储历程,将第8~9的字符交换成中国
execp_stufftb,content,8,2,中国,
select*fromtb
droptabletb
--*/
createprocp_stuff
@tbnamesysname,--要处置的表名
@fdnamesysname,--text/ntext字段名
@startint=null,--入手下手地位,NULL暗示追加数据
@lengthint=null,--交换的长度
@strnvarchar(4000),--要拔出的字符串
@wherenvarchar(1000)=--要处置的纪录的前提
as
if@strisnullreturn
declare@snvarchar(4000)
set@s=
declare@idint,@ptrvarbinary(16),@start1int
declaretbcursorlocalfor
selectid,start=datalength([+@fdname+])/2
from[+@tbname+]
+caseisnull(@where,)whenthen
elsewhere+@whereend+
opentb
fetchtbinto@id,@start1
while@@fetch_status=0
begin
select@ptr=textptr(content)
from[+@tbname+]
whereid=@id
if@startisnullor@start1<@start
updatetext[+@tbname+].[+@fdname+]@ptrnullnull@str
else
begin
set@start1=@start-1
updatetext[+@tbname+].[+@fdname+]@ptr@start1@length@str
end
fetchtbinto@id,@start1
end
closetb
deallocatetb

execsp_executesql@s
,N@startint,@lengthint,@strnvarchar(4000)
,@start,@length,@str
go

这章描述如何检查和处理在MySQL数据库中的数据损坏。如果你的表损坏很多,你应该尝试找出其原因!见G.1调试一个MySQL服务器。
乐观 该用户已被删除
沙发
发表于 2015-1-19 10:42:07 | 只看该作者
从项目平台的选择上讲,我们关心的,应该是一款产品能不能满足任务需求,而不是网上怎么说。
若天明 该用户已被删除
板凳
 楼主| 发表于 2015-1-28 05:58:12 | 只看该作者
对于微软系列的东西除了一遍遍尝试还真没有太好的办法
简单生活 该用户已被删除
地板
发表于 2015-2-5 18:16:43 | 只看该作者
微软对CLR作了大篇幅的宣传,这是因为数据库产品终于融入.net体系中。最开始我们也是狂喜,感觉对象数据库的一些概念可以实现了。
再现理想 该用户已被删除
5#
发表于 2015-2-13 05:46:46 | 只看该作者
可以动态传入参数,省却了动态SQL的拼写。
小魔女 该用户已被删除
6#
发表于 2015-3-3 16:13:35 | 只看该作者
连做梦都在想页面结构是怎么样的,绝非虚言
山那边是海 该用户已被删除
7#
发表于 2015-3-11 12:17:40 | 只看该作者
我个人认为就是孜孜不懈的学习
冷月葬花魂 该用户已被删除
8#
发表于 2015-3-18 12:43:13 | 只看该作者
XML字段类型更好的解决了XML数据的操作。XQuery确实不错,但是个人对其没好感。(CSDN的开发者应该是相当的熟了!)
透明 该用户已被删除
9#
发表于 2015-3-25 23:18:15 | 只看该作者
光写几个SQL实在叫无知。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-12-22 18:53

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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