Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

Masseneinfügung von Feldern mit fester Breite

Ich denke, Sie müssen eine Formatdatei definieren

z. B.

BULK INSERT TableA FROM 'C:\Temp\TableA.txt'
WITH FORMATFILE = 'C:\Temp\Format.xml'
SELECT * FROM TableA

Damit das funktioniert, benötigen Sie natürlich eine Formatdatei.

Allgemeine Informationen zum Erstellen finden Sie hier:

Erstellen einer Formatdatei

Wenn man sich das Schema ansieht, könnte es ungefähr so ​​aussehen:

<?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="CharFixed" LENGTH="3"/>
  <FIELD ID="2" xsi:type="CharFixed" LENGTH="3"/>
</RECORD>
<ROW>
  <COLUMN SOURCE="1" NAME="Field1" xsi:type="SQLCHAR" LENGTH="3"/>
  <COLUMN SOURCE="2" NAME="Field2" xsi:type="SQLCHAR" LENGTH="3"/>
</ROW>
</BCPFORMAT>