усечение строк и столбцов при спулинге в sqlplus - PullRequest
2 голосов
/ 03 июля 2019

* Я буферизирую некоторые данные из базы данных Oracle в CSV-файл, используя sqlplus, моя результирующая таблица содержит 44 столбца и более 7000 строк, но при буферизации в csv в Excel отображаются только 26 столбцов (от индекса A до Z) некоторые строки усекаются. Я хочу, чтобы все столбцы были напечатаны в одну строку. Я попытался увеличить «размер строки», но максимальный размер равен 32767, поэтому он не работает, и я попытался «перенести», но столбцы после 26-го (Z в Excel) индекса идут в следующей строке.

SET echo off
set embedded on
SET linesize 32767
SET LONG 90000 
SET LONGCHUNKSIZE 90000 
SET wrap off
SET heading off
SET pagesize 1000;
SET feed off;
SET colsep ',' 
SET termout off;
set trimout on;
SET trimspool ON; 
SELECT * FROM ix_web_user;
spool results.csv append;
SET newpage none;
/
spool off

Я хочу, чтобы все столбцы печатались в одной строке, а строки не должны быть усечены. *

1 Ответ

0 голосов
/ 04 июля 2019

Вы можете экспортировать несколько файлов CSV с разными столбцами, но один столбец в каждом файле должен иметь уникальный идентификатор строки. Например, первый файл содержит 22 столбца, а второй - 23 столбца. Простой скрипт соединяет строки по идентификатору и получается конечный файл с 44 столбцами и длиной строки более 32768.

file1.csv

id,col1,col2,col3,col4,col5,col6,col7,col8,col9,col10,col11,col12,col13,col14,col15,col16,col17,col18,col19,col20,col21,col22,col23,col24,col25,col26,col27,col28,col29,col30,col31,col32,col33,col34,col35,col36,col37,col38,col39,col40,col41,col42,col43
joe,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,2411111111111111111111111111111111111111111111111111111111111
sam,21,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,451111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111
mary,31,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,30111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111

file2.csv

id,col1,col2,col3,col4,col5,col6,col7,col8,col9,col10,col11,col12,col13,col14,col15,col16,col17,col18,col19,col20,col21
joe,33311111111111111111111111111111111111111111111111111111111111111111111111111111111111,33311111111111111111111111111111111111111111111111111111111111111111111111111111111111
mary,5551111111111111111111111111111111111111111111111111111111111111111111111111111111111,5551111111111111111111111111111111111111111111111111111111111111111111111111111111111
sam,44411111111111111111111111111111111111111111111111111111111111111111111111111111111111,44411111111111111111111111111111111111111111111111111111111111111111111111111111111111

файл merge.ps1

$file1=(import-csv file1.csv -header id,col1,col2,col3,col4,col5,col6,col7,col8,col9,col10,
                                     col11,col12,col13,col14,col15,col16,col17,col18,col19,col20,
                                     col21,col22,col23,col24,col25,col26,col27,col28,col29,col30,
                                     col31,col32,col33,col34,col35,col36,col37,col38,col39,col40,
                                     col41,col42,col43)[1..9999]
$file2=(import-csv file2.csv -header id,col1,col2,col3,col4,col5,col6,col7,col8,col9,col10,
                                     col11,col12,col13,col14,col15,col16,col17,col18,col19,col20,
                                     col21)[1..9999]
$file1|
   %{
      $id=$_.id
      $m=$file2|?{$_.id -eq $id}
      $_.col23=$m.col1
      $_.col24=$m.col2
      $_.col25=$m.col3
      $_.col26=$m.col4
      $_.col27=$m.col5
      $_.col28=$m.col6
      $_.col29=$m.col7
      $_.col30=$m.col8
      $_.col31=$m.col9
      $_.col32=$m.col10
      $_.col33=$m.col11
      $_.col34=$m.col12
      $_.col35=$m.col13
      $_.col36=$m.col14
      $_.col37=$m.col15
      $_.col38=$m.col16
      $_.col39=$m.col17
      $_.col40=$m.col18
      $_.col41=$m.col19
      $_.col42=$m.col20
      $_.col43=$m.col21

    }
$file1|Export-Csv "file3.csv" -NoTypeInformation

выходной файл3.csv

"id","col1","col2","col3","col4","col5","col6","col7","col8","col9","col10","col11","col12","col13","col14","col15","col16","col17","col18","col19","col20","col21","col22","col23","col24","col25","col26","col27","col28","col29","col30","col31","col32","col33","col34","col35","col36","col37","col38","col39","col40","col41","col42","col43"
"joe","1","2","3","4","5","6","7","8","9","10","11","12","13","14","15","16","17","18","19","20","2411111111111111111111111111111111111111111111111111111111111",,"33311111111111111111111111111111111111111111111111111111111111111111111111111111111111","33311111111111111111111111111111111111111111111111111111111111111111111111111111111111",,,,,,,,,,,,,,,,,,,
"sam","21","2","3","4","5","6","7","8","9","10","11","12","13","14","15","16","17","18","19","20","451111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111",,"44411111111111111111111111111111111111111111111111111111111111111111111111111111111111","44411111111111111111111111111111111111111111111111111111111111111111111111111111111111",,,,,,,,,,,,,,,,,,,
"mary","31","2","3","4","5","6","7","8","9","10","11","12","13","14","15","16","17","18","19","20","30111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111",,"5551111111111111111111111111111111111111111111111111111111111111111111111111111111111","5551111111111111111111111111111111111111111111111111111111111111111111111111111111111",,,,,,,,,,,,,,,,,,,
...