透明 发表于 2015-1-16 22:39:45

MSSQL网站制作之怎样有前提的分步删除数据表中的纪录

对于insert和delete,event中包含了插入/删除的记录的所有字段的值(太爽了。。)数据|前提怎样有前提的分步删除数据表中的纪录作者:eygle出处:http://blog.eygle.com日期:February22,2005
«本人下手,人给家足|Blog首页
偶然候我们必要分派删除数据表的一些纪录,分批提交以削减关于Undo的利用,本文供应一个复杂的存储历程用于完成该逻辑。
你能够依据你的必要举行得当调剂,本例仅供参考:


SQL>createtabletestasselect*fromdba_objects;Tablecreated.SQL>createorreplaceproceduredeleteTab2/**3**Usage:runthescripttocreatetheprocdeleteTab4**inSQL*PLUS,type"execdeleteTab(Foo,ID>=1000000,3000);"5**todeletetherecordsinthetable"Foo",commitper3000records.6**7**/8(9p_TableNameinvarchar2,--TheTableNamewhichyouwanttodeletefrom10p_Conditioninvarchar2,--Deletecondition,suchas"id>=100000"11p_Countinvarchar2--CommitafterdeleteHowmanyrecords12)13as14pragmaautonomous_transaction;15n_deletenumber:=0;16begin17while1=1loop18EXECUTEIMMEDIATE19deletefrom||p_TableName||where||p_Condition||andrownum<=:rn20USINGp_Count;21ifSQL%NOTFOUNDthen22exit;23else24n_delete:=n_delete+SQL%ROWCOUNT;25endif;26commit;27endloop;28commit;29DBMS_OUTPUT.PUT_LINE(Finished!);30DBMS_OUTPUT.PUT_LINE(Totally||to_char(n_delete)||recordsdeleted!);31end;32/Procedurecreated.SQL>insertintotestselect*fromdba_objects;6374rowscreated.SQL>/6374rowscreated.SQL>/6374rowscreated.SQL>commit;Commitcomplete.SQL>execdeleteTab(TEST,object_id>0,3000)Finished!Totally19107recordsdeleted!PL/SQLproceduresuccessfullycompleted.

很复杂,可是想来也有人能够用到。
mysql使用内部操作字符集gbk来进行操作,即执行"SELECT*FROMtestWHEREname=xxxor1=1/*LIMIT1";从而注入成功

小魔女 发表于 2015-1-19 20:54:05

比如日志传送、比如集群。。。

蒙在股里 发表于 2015-1-28 10:35:53

多走走一此相关论坛,多看一些实例开发,多交流0经验,没什么的,我也是刚学没多久!加油

飘灵儿 发表于 2015-2-5 18:31:59

如果,某一版本可以提供强大的并发响应,但是没有Oracle的相应版本稳定,或者价格较贵,那么,它就是不适合的。

再现理想 发表于 2015-2-13 05:50:13

多走走一此相关论坛,多看一些实例开发,多交流0经验,没什么的,我也是刚学没多久!加油

灵魂腐蚀 发表于 2015-3-3 15:41:10

呵呵,这就是偶想说的

变相怪杰 发表于 2015-3-11 11:51:26

每天坚持做不一样的是,认真做笔录,定时复习。一个月你就可以有一定的收获。当然如果你想在sql方面有一定的造诣,你少不了需要看很多很多的书籍了。

兰色精灵 发表于 2015-3-18 10:25:53

varchar(max)\\\\nvarchar(max)类型的引入大大的提高了编程的效率,可以使用字符串函数对CLOB类型进行操作,这是一个亮点。

愤怒的大鸟 发表于 2015-3-25 17:35:59

可能有的朋友会抱怨集成的orderby,其实如果使用ranking函数,Orderby是少不了的。如果担心Orderby会影响效率,可以为orderby的字段建立聚集索引,查询计划会忽略orderby操作(因为本来就是排序的嘛)。
页: [1]
查看完整版本: MSSQL网站制作之怎样有前提的分步删除数据表中的纪录