数据库数据处理并转移问题[sqlserver2000]

Solidsnake1987 2009-10-28 10:24:26
遇到了一个没有使用sqlserver方式处理的问题.

本身这个数据转移是在java程序里面做的, 结果老大说数据库应该已经有这种功能, 不让我从新造轮子.

但是问题就出来了, 仅仅是整个数据的迁移不是问题, 但是在迁移的过程中却有逻辑(两个数据库的字段设计不同), 比如会根据一个字段的值来判断导入数据源对应type字段的值, 而这些值都是有一定的筛选条件的.

我现在想问的是, 哪个朋友做过这样的操作, 可以给我一点点提示, 最好可以提供一个例子, 感激不尽.

如果是DTS可以实现, 最好也带上步骤的例子.
...全文
123 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
pbsh 2009-10-30
  • 打赏
  • 举报
回复
预先写好脚本处理数据,然后使用DTS导出到目标。
或者使用SSIS,数据流中间使用组建进行转换。
zhouzhijian888 2009-10-28
  • 打赏
  • 举报
回复
...
--小F-- 2009-10-28
  • 打赏
  • 举报
回复
****************************************************************************
软件名称: May Flower Erp
版权所有: (C) 2005-2006 May Flower ERP 开发组
功能描述: 获取指定表的创建脚本,包括表和字段的属性、外键(注释掉的)
----------------------------------------------------------------------------
参数列表:
1: @TableName 需要创建脚本的表的名称
****************************************************************************
|</PRE>*/
CREATE PROCEDURE [dbo].[sp_HelpTable](@TableName sysname)
AS
SET NOCOUNT ON
DECLARE @ObjectID int
DECLARE @TableScript table(Iden int IDENTITY(1, 1), ScriptLine nvarchar(4000))
SET @ObjectID = object_id(@TableName)
IF @ObjectID IS NULL OR OBJECTPROPERTY(@ObjectID, 'IsTable') = 0
BEGIN
RAISERROR('指定的对象不是表对象', 16, 1)
RETURN
END
--获取表的创建脚本
--插入表头
INSERT INTO @TableScript(ScriptLine)
SELECT N'CREATE TABLE [' + USER_NAME(OBJECTPROPERTY(@ObjectID, N'OwnerId')) + N'].[' + object_name(@ObjectID) + N']('

--插入字段
INSERT INTO @TableScript(ScriptLine)
SELECT N' [' + a.Name + N'] [' + b.name + N']' +
CASE WHEN c.Object_id IS NOT NULL THEN N' IDENTITY(' + CONVERT(nvarchar, c.seed_value) + N', ' + CONVERT(nvarchar, c.increment_value) + N')'
ELSE '' END +
CASE WHEN b.xusertype IN (167, 175, 231, 239) THEN N'('+CONVERT(nvarchar, a.prec) + N')'
WHEN b.xusertype in (106, 108) THEN N'('+CONVERT(nvarchar, a.xprec) + N', ' + CONVERT(nvarchar, a.xscale) + N')'
ELSE '' END +
CASE a.isnullable WHEN 1 THEN N'' ELSE N' NOT' END + N' NULL' +
CASE WHEN d.Name IS NOT NULL THEN N' DEFAULT ' + d.Definition ELSE N'' END +
N','
FROM sys.syscolumns a
LEFT JOIN sys.systypes b ON a.xusertype = b.xusertype
LEFT JOIN sys.identity_columns c ON c.Object_id = a.ID AND c.Column_ID = a.ColID
LEFT JOIN sys.default_constraints d ON d.Parent_Object_ID = a.ID AND d.Parent_column_ID = a.ColID
WHERE a.[ID] = @ObjectID
ORDER BY a.ColOrder

--插入主键和索引
DECLARE @IndexID int, @IndexScript nvarchar(4000)
DECLARE IndexCursor CURSOR FOR
SELECT b.Index_ID, N' CONSTRAINT [' + a.Name + N'] ' +
CASE a.Type WHEN 'PK' THEN N'PRIMARY KEY ' WHEN 'UQ' THEN N'UNIQUE ' END +
CASE b.Type WHEN 1 THEN N'CLUSTERED' WHEN 2 THEN N'NONCLUSTERED ' END + N'('
FROM sys.key_constraints a
LEFT JOIN sys.indexes b ON b.Object_ID = a.Parent_Object_ID AND b.index_id = a.unique_index_id
WHERE a.Parent_Object_ID = @ObjectID
OPEN IndexCursor
FETCH NEXT FROM IndexCursor INTO @IndexID, @IndexScript
WHILE @@FETCH_STATUS = 0
BEGIN
SELECT @IndexScript = @IndexScript + N'[' + INDEX_COL(object_name(@ObjectID), 2 , 1) + N'],'
FROM sys.index_columns
WHERE Object_ID = @ObjectID
AND Index_ID = 2

SET @IndexScript = LEFT(@IndexScript, LEN(@IndexScript) -1) + N'),'
INSERT INTO @TableScript(ScriptLine) VALUES(@IndexScript)
FETCH NEXT FROM IndexCursor INTO @IndexID, @IndexScript
END
Close IndexCursor
DEALLOCATE IndexCursor

insert into @TableScript(ScriptLine) VALUES(')')
select * from @TableScript



本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/fredrickhu/archive/2009/10/14/4669511.aspx
taoistong 2009-10-28
  • 打赏
  • 举报
回复
[Quote=引用楼主 solidsnake1987 的回复:]
遇到了一个没有使用sqlserver方式处理的问题.

本身这个数据转移是在java程序里面做的, 结果老大说数据库应该已经有这种功能, 不让我从新造轮子.

但是问题就出来了, 仅仅是整个数据的迁移不是问题, 但是在迁移的过程中却有逻辑(两个数据库的字段设计不同), 比如会根据一个字段的值来判断导入数据源对应type字段的值, 而这些值都是有一定的筛选条件的.

我现在想问的是, 哪个朋友做过这样的操作, 可以给我一点点提示, 最好可以提供一个例子, 感激不尽.

如果是DTS可以实现, 最好也带上步骤的例子. 
[/Quote]


从源头把数据导到excel里面,之后再把这个excel导入到目的数据库
fwacky 2009-10-28
  • 打赏
  • 举报
回复
这个,有点难度!
只能帮顶了!
Solidsnake1987 2009-10-28
  • 打赏
  • 举报
回复
最好可以给出步骤的例子, 因为我对数据库方面不是很了解
--小F-- 2009-10-28
  • 打赏
  • 举报
回复
获取当前数据库所有表的外键创建脚本、获取指定表的创建脚本,包括表和字段的属性、外键

http://blog.csdn.net/fredrickhu/archive/2009/10/14/4669511.aspx
SQL77 2009-10-28
  • 打赏
  • 举报
回复
先处理再导出不行??
或先导入再处理??
用DTS应该可以

27,582

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧