55

我有一个包含以下数据的表:

Pk_Id  ProductName           Fk_CompanyId       Price
------------------------------------------------------
1      AMX                   1                  10.00
2      ABC                   1                  11.00
3      APEX                  1                  12.00
4      AMX                   1                  10.00
5      ABC                   1                  11.00
6      APEX                  1                  12.00
7      AMX                   2                  10.00
8      ABC                   2                  11.00
9      APEX                  2                  12.00

我想为迁移 Fk_CompanyId 为 1 的记录生成插入脚本。

有一个插入脚本选项可以为所有记录生成脚本,但我想过滤一些记录以迁移到另一个数据库。

4

12 回答 12

46

如果您使用的是 SQL Management Studio,您可以右键单击您的数据库名称并选择任务 > 导入/导出数据并按照向导进行操作。
其中一个步骤称为“指定表副本或查询”,其中可以选择编写查询以指定要传输的数据,因此您可以简单地指定以下查询:

select * from [Table] where Fk_CompanyId = 1
于 2012-07-19T12:20:44.223 回答
40

如果可能,请使用 Visual Studio。自 2014 年 3 月发布以来,Microsoft SQL Server Data Tools (SSDT) 为此带来了内置功能:

  1. 打开 Visual Studio
  2. 打开“查看”→“SQL Server 对象资源管理器”
  3. 添加到您的服务器的连接
  4. 展开相关数据库
  5. 展开“表格”文件夹
  6. 右键单击相关表
  7. 从上下文菜单中选择“查看数据”
  8. 在新窗口中,查看数据使用工具栏中的“排序和过滤数据集”功能来应用您的过滤器。请注意,此功能是有限的,您不能编写显式 SQL 查询。
  9. 应用过滤器并仅查看所需数据后,单击工具栏中的“脚本”或“脚本到文件”
  10. Voilà - 在这里你有你的过滤数据的插入脚本

注意:请注意,“查看数据”窗口就像 SSMS“编辑前 200 行”一样 - 您可以立即编辑数据

(使用 Visual Studio 2015 和 Microsoft SQL Server Data Tools (SSDT) 版本 14.0.60812.0 和 Microsoft SQL Server 2012 进行测试)

于 2018-07-05T08:35:56.340 回答
26
CREATE PROCEDURE sp_generate_insertscripts
(
    @TABLENAME VARCHAR(MAX),
    @FILTER_CONDITION VARCHAR(MAX)=''   -- where TableId = 5 or some value
)
AS
BEGIN

SET NOCOUNT ON

DECLARE @TABLE_NAME VARCHAR(MAX),
        @CSV_COLUMN VARCHAR(MAX),
        @QUOTED_DATA VARCHAR(MAX),
        @TEXT VARCHAR(MAX),
        @FILTER VARCHAR(MAX) 

SET @TABLE_NAME=@TABLENAME

SELECT @FILTER=@FILTER_CONDITION

SELECT @CSV_COLUMN=STUFF
(
    (
     SELECT ',['+ NAME +']' FROM sys.all_columns 
     WHERE OBJECT_ID=OBJECT_ID(@TABLE_NAME) AND 
     is_identity!=1 FOR XML PATH('')
    ),1,1,''
)

SELECT @QUOTED_DATA=STUFF
(
    (
     SELECT ' ISNULL(QUOTENAME('+NAME+','+QUOTENAME('''','''''')+'),'+'''NULL'''+')+'','''+'+' FROM sys.all_columns 
     WHERE OBJECT_ID=OBJECT_ID(@TABLE_NAME) AND 
     is_identity!=1 FOR XML PATH('')
    ),1,1,''
)

SELECT @TEXT='SELECT ''INSERT INTO '+@TABLE_NAME+'('+@CSV_COLUMN+')VALUES('''+'+'+SUBSTRING(@QUOTED_DATA,1,LEN(@QUOTED_DATA)-5)+'+'+''')'''+' Insert_Scripts FROM '+@TABLE_NAME + @FILTER

--SELECT @CSV_COLUMN AS CSV_COLUMN,@QUOTED_DATA AS QUOTED_DATA,@TEXT TEXT

EXECUTE (@TEXT)

SET NOCOUNT OFF

END
于 2016-04-06T09:30:58.337 回答
19
SELECT 'INSERT SomeOtherDB.dbo.table(column1,column2,etc.)
  SELECT ' + CONVERT(VARCHAR(12), Pk_Id) + ','
       + '''' + REPLACE(ProductName, '''', '''''') + ''','
       + CONVERT(VARCHAR(12), Fk_CompanyId) + ','
       + CONVERT(VARCHAR(12), Price) + ';'
FROM dbo.unspecified_table_name
WHERE Fk_CompanyId = 1;
于 2012-07-19T12:22:54.003 回答
7

实际上,我只需几个步骤即可在 SSMS 中完成此操作,而无需添加插件或过程。1)如果您不想要整个表,请选择需要的列和记录到数据库中的新表中:SELECT col1, col2 ... INTO TempRecs 2)使用 SSMS 的生成脚本功能通过右键单击数据库来生成 INSERT 语句(任务 > 生成脚本> 选择对象 > 选择临时表 > 单击高级按钮 > 将“脚本的数据类型”更改为“仅数据”> 完成)。3) 对临时表名上的结果 INSERT 语句进行查找并替换为所需的导入表名。

于 2016-05-04T15:48:17.483 回答
6

在 SSMS 中执行您的 sql 查询。从结果窗口中选择所有单元格并复制值。转到下面的网站,您可以在那里粘贴复制的数据并生成 sql 脚本。您还可以将 SSMS 的查询结果保存为 CSV 文件,并将 csv 文件导入网站。

http://www.convertcsv.com/csv-to-sql.htm

于 2016-11-08T09:46:27.937 回答
5

您可以使用您的标准创建一个视图,然后导出该视图吗?

于 2012-07-19T12:20:37.030 回答
4

使用DBeaver客户端(支持 SQL Server),您可以使用所需的记录执行 SELECT 查询,然后选择结果行,右键单击并复制为 SQL,您将在剪贴板中拥有 INSERT 语句:

在此处输入图像描述



HeidiSQL还支持连接到 SQL Server 并导出选定的行(您可以在 SQL 查询本身中过滤行,或者检索所有行并在数据网格中选择它们):

在此处输入图像描述

于 2021-06-02T15:09:55.707 回答
2

我创建了以下内容procedure

if object_id('tool.create_insert', 'P') is null
begin
  exec('create procedure tool.create_insert as');
end;
go

alter procedure tool.create_insert(@schema    varchar(200) = 'dbo',
                                   @table     varchar(200),
                                   @where     varchar(max) = null,
                                   @top       int = null,
                                   @insert    varchar(max) output)
as
begin
  declare @insert_fields varchar(max),
          @select        varchar(max),
          @error         varchar(500),
          @query         varchar(max);

  declare @values table(description varchar(max));

  set nocount on;

  -- Get columns
  select @insert_fields = isnull(@insert_fields + ', ', '') + c.name,
         @select = case type_name(c.system_type_id)
                      when 'varchar' then isnull(@select + ' + '', '' + ', '') + ' isnull('''''''' + cast(' + c.name + ' as varchar) + '''''''', ''null'')'
                      when 'datetime' then isnull(@select + ' + '', '' + ', '') + ' isnull('''''''' + convert(varchar, ' + c.name + ', 121) + '''''''', ''null'')'
                      else isnull(@select + ' + '', '' + ', '') + 'isnull(cast(' + c.name + ' as varchar), ''null'')'
                    end
    from sys.columns c with(nolock)
         inner join sys.tables t with(nolock) on t.object_id = c.object_id
         inner join sys.schemas s with(nolock) on s.schema_id = t.schema_id
   where s.name = @schema
     and t.name = @table;

  -- If there's no columns...
  if @insert_fields is null or @select is null
  begin
    set @error = 'There''s no ' + @schema + '.' + @table + ' inside the target database.';
    raiserror(@error, 16, 1);
    return;
  end;

  set @insert_fields = 'insert into ' + @schema + '.' + @table + '(' + @insert_fields + ')';

  if isnull(@where, '') <> '' and charindex('where', ltrim(rtrim(@where))) < 1
  begin
    set @where = 'where ' + @where;
  end
  else
  begin
    set @where = '';
  end;

  set @query = 'select ' + isnull('top(' + cast(@top as varchar) + ')', '') + @select + ' from ' + @schema + '.' + @table + ' with (nolock) ' + @where;

  insert into @values(description)
  exec(@query);

  set @insert = isnull(@insert + char(10), '') + '--' + upper(@schema + '.' + @table);

  select @insert = @insert + char(10) + @insert_fields + char(10) + 'values(' + v.description + ');' + char(10) + 'go' + char(10)
    from @values v
   where isnull(v.description, '') <> '';
end;
go

然后你可以这样使用它:

declare @insert varchar(max),
        @part   varchar(max),
        @start  int,
        @end    int;

set @start = 1;

exec tool.create_insert @schema = 'dbo',
                        @table = 'myTable',
                        @where  = 'Fk_CompanyId = 1',
                        @insert = @insert output;

-- Print one line to avoid the maximum 8000 characters problem
while len(@insert) > 0
begin
  set @end = charindex(char(10), @insert);

  if @end = 0
  begin
    set @end = len(@insert) + 1;
  end;

  print substring(@insert, @start, @end - 1);
  set @insert = substring(@insert, @end + 1, len(@insert) - @end + 1);
end;

输出将是这样的:

--DBO.MYTABLE
insert into dbo.myTable(Pk_Id, ProductName, Fk_CompanyId, Price)
values(1, 'AMX', 1, 10.00);
go

insert into dbo.myTable(Pk_Id, ProductName, Fk_CompanyId, Price)
values(2, 'ABC', 1, 11.00);
go

insert into dbo.myTable(Pk_Id, ProductName, Fk_CompanyId, Price)
values(3, 'APEX', 1, 12.00);
go

insert into dbo.myTable(Pk_Id, ProductName, Fk_CompanyId, Price)
values(4, 'AMX', 1, 10.00);
go

insert into dbo.myTable(Pk_Id, ProductName, Fk_CompanyId, Price)
values(5, 'ABC', 1, 11.00);
go

insert into dbo.myTable(Pk_Id, ProductName, Fk_CompanyId, Price)
values(6, 'APEX', 1, 12.00);
go

insert into dbo.myTable(Pk_Id, ProductName, Fk_CompanyId, Price)
values(7, 'AMX', 2, 10.00);
go

insert into dbo.myTable(Pk_Id, ProductName, Fk_CompanyId, Price)
values(8, 'ABC', 2, 11.00);
go

insert into dbo.myTable(Pk_Id, ProductName, Fk_CompanyId, Price)
values(9, 'APEX', 2, 12.00);
go

如果您只想获取一系列行,请使用以下@top参数:

declare @insert varchar(max),
        @part   varchar(max),
        @start  int,
        @end    int;

set @start = 1;

exec tool.create_insert @schema = 'dbo',
                        @table = 'myTable',
                        @top    = 100,
                        @insert = @insert output;

-- Print one line to avoid the maximum 8000 characters problem
while len(@insert) > 0
begin
  set @end = charindex(char(10), @insert);

  if @end = 0
  begin
    set @end = len(@insert) + 1;
  end;

  print substring(@insert, @start, @end - 1);
  set @insert = substring(@insert, @end + 1, len(@insert) - @end + 1);
end;
于 2017-04-07T13:25:15.983 回答
0

如果您使用的是 Oracle SQL Developer,那么它将是

select /*insert*/ * from TABLE_NAME where COLUMN_NAME = 'VALUE';

将此作为脚本运行

于 2015-11-30T05:09:57.027 回答
0

如果您使用的是 MySql 和 MySql 工作台。这是一个不错的选择。

  1. 编写您的选择查询并执行它
  2. 您将看到“导出”按钮
  3. 项目清单
  4. 单击它并提供文件名,然后在“另存为类型”中,您将看到“SQL 插入语句”

这将为您提供插入语句

在此处输入图像描述

于 2021-03-10T12:34:20.900 回答
0

使用 Navicat

  1. 过滤表中的数据或编写查询

第一步

  1. 选择行并右键单击它>复制AS>选择“插入语句”或“更新语句”

第二步

  1. 在 MS SQL Server Management Studio 或其他 IDE 中粘贴新查询

第三步

于 2021-11-22T10:32:35.700 回答