国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

SQL Server Bulk Insert 只需要部分字段時的方法

2024-08-31 00:58:07
字體:
供稿:網(wǎng)友
根據(jù)一般做法的話,導(dǎo)出部分字段時沒有辦法生成格式化XML文件,所以導(dǎo)入時就沒有辦法格式化導(dǎo)入數(shù)據(jù)。

我想到兩點,1.手工修改格式化XML文件,2.創(chuàng)造一個能生成格式化XML文件的中間對象。

在MSDN中尋找方法時,突然想到可以使用視圖來做中間對象,于是就搭一個測試下。以下是測試記錄:

復(fù)制代碼 代碼如下:


USE master
GO
CREATE DATABASE [db_test]
GO
USE db_test
GO
CREATE TABLE dbo.T_test(
ID [int] IDENTITY(1,1) NOT NULL,
Code varchar(10) ,
Name varchar(100) ,
Memo nvarchar(500) ,
Memo2 ntext ,
PRIMARY KEY (ID)
)
GO
--上面創(chuàng)建的表是源數(shù)據(jù)表,下面創(chuàng)建是要導(dǎo)入數(shù)據(jù)的表,只有源表的三個字段
Select Code, Name,Memo into dbo.T_test2 from dbo.T_test Where 1=2

--需求就是把表T_test中的Code,Name導(dǎo)入到T_test2。
--接下來,就是生成導(dǎo)入目標(biāo)表的格式化XML文件,可是MSDN上說只能生成某個對象的格式化XML文件。
--只好建立一個中間對象來達(dá)到目的,這里我創(chuàng)建的是一個視圖。
--視圖只包含需要導(dǎo)入的字段
Create View v_test
AS
Select Code,Name From dbo.T_test2
--然后就是BCP操作
EXEC sp_configure 'show advanced options', 1;
RECONFIGURE;
EXEC sp_configure 'xp_cmdshell', 1;
EXEC sp_configure 'show advanced options', 0;
RECONFIGURE;
GO
EXEC master..xp_cmdshell 'BCP db_test.dbo.v_test format nul -f C:/v_test_fmt.xml -x -c -T -S MyPC/MyDB'
GO
EXEC master..xp_cmdshell 'BCP "select Code, Name from db_test.dbo.T_test" queryout C:/t_test.data -f C:/v_test_fmt.xml -T -S MyPC/MyDB'
GO

--格式化文件和數(shù)據(jù)文件都有了,就成了.
BULK INSERT db_mgr.dbo.v_t1
FROM N'C:/t_test.data'
WITH
(
FORMATFILE = N'C:/v_test_fmt.xml'
)
GO
EXEC sp_configure 'show advanced options', 1;
RECONFIGURE;
EXEC sp_configure 'xp_cmdshell', 0;
EXEC sp_configure 'show advanced options', 0;
RECONFIGURE;
GO
Drop Database db_test
GO


環(huán)境是sql2005。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 衡阳县| 万宁市| 来宾市| 五寨县| 锡林浩特市| 金寨县| 舞阳县| 眉山市| 昌宁县| 土默特左旗| 泸州市| 安西县| 建湖县| 满洲里市| 明水县| 邵武市| 白沙| 曲阜市| 兰溪市| 盐亭县| 拜城县| 山东| 响水县| 额尔古纳市| 吉木萨尔县| 柘荣县| 嫩江县| 晋江市| 连平县| 湖口县| 新安县| 杭锦旗| 蓝田县| 福清市| 盐城市| 上高县| 宿州市| 鹰潭市| 南汇区| 龙海市| 南汇区|