日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

关于MSSQL导入导出时主键与约束丢失的问题解决

發布時間:2023/11/27 生活经验 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 关于MSSQL导入导出时主键与约束丢失的问题解决 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

導入數據時,使用默認選項,會丟失主鍵、約束、默認值等屬性,按如下步驟操作:

-->導出向導?
-->選擇數據源?
-->選擇目的?
-->指定表復制或查詢:不要使用默認選項,選擇“在SQL Server數據庫之間復制對象和數據”?
-->選擇要復制的對象:在本頁中根據需要選擇相應的開關項,對于列約束,必須選擇“擴展屬性”,若去掉“復制所有對象”,可以選擇你要導出的表或對象?
-->其余按默認步驟即可?
下面是詳細流程:

1、打開本地企業管理器,先創建一個SQL Server注冊來遠程連接服務器端口SQL Server。
步驟如下圖:

圖1:


2、彈出窗口后輸入內容。"總是提示輸入登陸名和密碼"可選可不選,如圖2。

圖2:


3、注冊好服務器后,點擊打開。如果是選擇了"總是提示輸入登陸名和密碼"的話再點了確定后會提示輸入用戶密碼,如圖3。

圖3:


4、進入后,選擇到您的數據庫,如testdb。在上面點右鍵,"所有任務">>"導入數據",如圖4。

圖4:

5、進入DTS導入/導出向導,點擊“下一步”按鈕繼續

圖5:

6、選擇數據源,輸入數據源所在的數據庫服務器名稱、用戶名、密碼和要復制數據的源數據庫,點擊“下一步”按鈕

圖6:

7、選擇“在SQL Server數據庫之間復制對象和數據”方式,點“下一步”繼續

圖7:

8、這一步可以把"包括擴展屬性"和"排序規則"兩個選擇上。接著去掉左下的"使用默認選項",點擊右下角的"選項"來進行配置。

圖8:

9、圖8中點"選項"后會彈出圖9,把"復制數據庫用戶和數據庫角色"與"復制對象級權限"兩個選項去掉,
點確定回到圖8接著點"下一步"進到圖10。

圖9:

10、設定調度方式,一般選“立即運行”就可以,然后點“下一步”繼續

圖10:

11、點"完成"開始執行。

圖11:

12、正在進行數據導入中

圖12:

13、如果一切正常,提示成功復制如圖13,那就大功告成了。

圖13:

?

SQL Server 導入/導出 錯誤排查

如果提示導入失敗,出現圖14情況,這時不要急著點"完成"關閉窗口。雙擊中間的"出現錯誤"會出現詳細的失敗原因。

圖14:

錯誤原因一、沒安裝SP3補丁

如果是出現如圖15的報錯原因,那么就很有可能是因為您本機的SQL Server還沒有打SP3補丁。

圖15:

如何查看是否已打了SP3補丁呢?右鍵點擊本地SQL Server屬性,彈出圖16窗口,查看"產品版本"一行。
像以下圖顯示8.00.760(SP3)說明已經打過補丁。如果您的企業管理器顯示的版本要比這個小,那就是沒打SP3補丁。
請安裝SQL Server SP3補丁后再重試。

圖16:

錯誤原因二、對象屬性沖突

如果出現圖17情況,那么應該就是您本地數據庫的表/視圖/存儲過程的屬主和服務器上數據庫默認用戶不一致。
服務器的用戶一般是:數據庫名+'_f',如我的數據庫名稱是testdb,則我在服務器上使用的數據庫用戶名就是testdb_f。
如圖18,我本地的表屬主是testuser,與服務器數據庫用戶名不一致,因此導入過程出錯。

圖17:

圖18:

解決方法是:
應該先把本地的所有表/視圖/存儲過程屬主都改為dbo或testdb_f(后者需要在本地創建起相應用戶。
建議創建,否則以后想從服務器上導出數據時同樣會因為這個問題導出錯誤),再重新進行導入/導出。

打開SQL查詢分析器,運行以下命令進行批量修改表屬主為dbo:

exec sp_MSForEachTable 'sp_changeobjectowner "?", "dbo"'

運行成功后表屬主會改變成如圖19:

圖19:

如果需要修改視圖/存儲過程,則麻煩了點。
下面有個方法可以實現:

一、先在master創建一個sp_MSforeachObject存儲過程,命令如下:

USE MASTER
GO
CREATE proc sp_MSforeachObject
@objectType int=1,
@command1 nvarchar(2000),?
@replacechar nchar(1) = N'?',?
@command2 nvarchar(2000) = null,
???? @command3 nvarchar(2000) = null,?
@whereand nvarchar(2000) = null,
@precommand nvarchar(2000) = null,?
@postcommand nvarchar(2000) = null
as
/* This proc returns one or more rows for each table (optionally, matching @where), with each table defaulting to its?
own result set */
/* @precommand and @postcommand may be used to force a single result set via a temp table. */
/* Preprocessor won't replace within quotes so have to use str(). */
declare @mscat nvarchar(12)
select @mscat = ltrim(str(convert(int, 0x0002)))
if (@precommand is not null)
?? exec(@precommand)
/* Defined?? @isobject for save object type */
Declare @isobject varchar(256)
select @isobject= case @objectType when 1 then 'IsUserTable'
???????? when 2 then 'IsView'
???????? when 3 then 'IsTrigger'
???????? when 4 then 'IsProcedure'?
???????? when 5 then 'IsDefault'???
???????? when 6 then 'IsForeignKey'
???????? when 7 then 'IsScalarFunction'
???????? when 8 then 'IsInlineFunction'
???????? when 9 then 'IsPrimaryKey'
???????? when 10 then 'IsExtendedProc'????
???????? when 11 then 'IsReplProc'
???????? when 12 then 'IsRule'
?????????????????? end
/* Create the select */
/* Use @isobject variable isstead of IsUserTable string */
EXEC(N'declare hCForEach cursor global for select ''['' + REPLACE(user_name(uid), N'']'', N'']]'') + '']'' + ''.'' + ''['' +?
REPLACE(object_name(id), N'']'', N'']]'') + '']'' from dbo.sysobjects o '
+ N' where OBJECTPROPERTY(o.id, N'''+@isobject+''') = 1 '+N' and o.category & ' + @mscat + N' = 0 '
+ @whereand)
declare @retval int
select @retval = @@error
if (@retval = 0)
exec @retval = sp_MSforeach_worker @command1, @replacechar, @command2, @command3
if (@retval = 0 and @postcommand is not null)
exec(@postcommand)
return @retval
GO

二、再運行以下命令批量修改表、觸發器、視圖、存儲過程的屬主(需要先在master創建sp_MSforeachObject存儲過程) EXEc sp_MSforeachObject @command1="sp_changeobjectowner '?', 'dbo'",@objectType=1
EXEc sp_MSforeachObject @command1="sp_changeobjectowner '?', 'dbo'",@objectType=2
EXEc sp_MSforeachObject @command1="sp_changeobjectowner '?', 'dbo'",@objectType=3
EXEc sp_MSforeachObject @command1="sp_changeobjectowner '?', 'dbo'",@objectType=4

此時再重新進行導入應該就能一切順利了。

轉載于:https://www.cnblogs.com/ken-admin/p/5826393.html

總結

以上是生活随笔為你收集整理的关于MSSQL导入导出时主键与约束丢失的问题解决的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。