【问题标题】:How to delete partial text from SQL table?如何从 SQL 表中删除部分文本?
【发布时间】:2014-09-09 13:32:09
【问题描述】:

一个破解者破解了我的 SQL 数据库,在大部分行中安装了以下脚本:

<script src=http://www.example.com/xx.js></script>

我需要在每一行中删除这个脚本,(不是行中的所有文本)我找到了命令:

DELETE FROM [tevalifeForum].[dbo].[FORUM_MEMBERS]
      WHERE <Search Conditions,,>
GO

但我不知道该怎么做。

【问题讨论】:

  • 从备份中恢复数据库并重新开始。你不知道黑客还做了什么。
  • 试试正则表达式。

标签: delete-row sql-delete


【解决方案1】:

假设您的列类型是 TEXT,并且您想删除该 TEXT 列中的行,这与我过去所做的类似:

DECLARE @script VARCHAR(100), @len INT, @i INT

SELECT
    @script = '<script src=http://www.example.com/xx.js></script>',
    @len = LEN(@script)

SELECT @i = MAX(DATALENGTH([col]))
    FROM [tevalifeForum].[dbo].[FORUM_MEMBERS]

UPDATE [tevalifeForum].[dbo].[FORUM_MEMBERS]
    SET [col] =
    LEFT(CAST([col] AS VARCHAR(MAX)), CHARINDEX(@script, [col])-1)
    + SUBSTRING(CAST([col] AS VARCHAR(MAX)), CHARINDEX(@script, [col])+ @len, @1)
    WHERE [col] LIKE '%' + @script + '%'

请确保您有一个有效的备份,并了解这只能通过从备份恢复来“撤消”。

【讨论】:

  • 您好,由于我不是程序员,我很困惑,如果您能再次回答我并输入我应该编写的确切命令,包括要删除的行,我将不胜感激。
  • 注入文本的列名是什么?
  • @user3731090,如果此答案解决了您的问题,请单击复选标记进行考虑。这向更广泛的社区表明您已经找到了解决方案,并为回答者和您自己提供了一些声誉。没有义务这样做。
猜你喜欢
  • 2013-01-09
  • 2021-05-18
  • 1970-01-01
  • 2023-01-20
  • 2021-08-23
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多