Solved

Process .txt file with a .xml format

Posted on 2014-09-11
2
81 Views
Last Modified: 2015-03-04
The below .xml processes a .txt file into a sql table.
Now this .txt file has changed where as 1-1 Contains part 1 of Repair Code and 22-23 contains part 2 of Repair code.
So, the Repair code is now 3 positions long instead of 2. The Repair Code Name is same length as before in positions 24-58.

How would I change below .xml to process this new 3 position Repair Code.
I mean the new 3 position Repair Code would have to be brought together so I can put it in a 3 Char sql field and the Repair Code Name would have to be put in the current 35 varchar field.
The old Repair Code was in positions 1-2 (see .xml below). Why they did not put the new Repair Code into positions 1-3 is a mystery to me.

Here is Stored Procedure code that processes this Repair Code table:

USE [FMR]
GO
/****** Object:  StoredProcedure [dbo].[LoadRepairCode]    Script Date: 09/11/2014 22:05:23 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO


ALTER PROCEDURE [dbo].[LoadRepairCode] AS

TRUNCATE TABLE dbo.RepairCode

EXECUTE sp_tableoption RepairCode, 'table lock on bulk load', 1

-- Perform the bulk insert of the flat-file received from the mainframe.
-- Note that the records are not all fixed-length.

INSERT INTO dbo.RepairCode
    SELECT *
     FROM OPENROWSET(BULK '\\fmrprdfiles\sqlprdfiles\FMR\data\RepairCode.txt',
     FORMATFILE='\\fmrprdfiles\sqlprdfiles\FMR\Formats\RepairCode.xml'
       ) AS Temp;


Here is the current RepairCode.xml'

<?xml version="1.0"?>
<BCPFORMAT xmlns="http://schemas.microsoft.com/sqlserver/2004/bulkload/format" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
 <RECORD>
  <FIELD ID="1" xsi:type="CharTerm" TERMINATOR="," MAX_LENGTH="2" COLLATION="SQL_Latin1_General_CP1_CI_AS"/>
  <FIELD ID="2" xsi:type="CharTerm" TERMINATOR="\r\n" MAX_LENGTH="35" COLLATION="SQL_Latin1_General_CP1_CI_AS"/>
 </RECORD>
 <ROW>
  <COLUMN SOURCE="1" NAME="RepCD" xsi:type="SQLCHAR"/>
  <COLUMN SOURCE="2" NAME="RepCd-Name" xsi:type="SQLVARYCHAR"/>
 </ROW>
</BCPFORMAT>
0
Comment
Question by:thayduck
2 Comments
 
LVL 142

Accepted Solution

by:
Guy Hengel [angelIII / a3] earned 500 total points
ID: 40318624
as you can check yourself in the XML format files:
http://msdn.microsoft.com/en-us/library/ms187833.aspx
it's not possible in the bulk import to directly combine 2 parts into 1 column

you will need to import into a staging table that has the needed structure, and go on from there.
0
 

Author Comment

by:thayduck
ID: 40319363
I did what you suggested and eveything is good now.

Thanks.
0

Featured Post

Complete VMware vSphere® ESX(i) & Hyper-V Backup

Capture your entire system, including the host, with patented disk imaging integrated with VMware VADP / Microsoft VSS and RCT. RTOs is as low as 15 seconds with Acronis Active Restore™. You can enjoy unlimited P2V/V2V migrations from any source (even from a different hypervisor)

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Occasionally there is a need to clean table columns, especially if you have inherited legacy data. There are obviously many ways to accomplish that, including elaborate UPDATE queries with anywhere from one to numerous REPLACE functions (even within…
International Data Corporation (IDC) prognosticates that before the current the year gets over disbursing on IT framework products to be sent in cloud environs will be $37.1B.
This video shows how to set up a shell script to accept a positional parameter when called, pass that to a SQL script, accept the output from the statement back and then manipulate it in the Shell.
This videos aims to give the viewer a basic demonstration of how a user can query current session information by using the SYS_CONTEXT function

863 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

18 Experts available now in Live!

Get 1:1 Help Now