Oui, PlaineR a raison. Si le fichier de données ne contient que des entiers il faut avoir:
etCode:
1
2
3
4
5
6
7
8 CREATE TABLE matable( date_mes DATE not null, valeur NUMBER(8), type_mes VARCHAR2(1) not null, freq_mes VARCHAR2(1) not null, id_mes NUMBER not null);
Avec les données suivantes:Code:
1
2
3
4
5
6 LOAD DATA INFILE 'matable.csv' TRUNCATE INTO TABLE MATABLE FIELDS TERMINATED BY ';' OPTIONALLY ENCLOSED BY '"' (ID_MES, DATE_MES "to_date(:date_mes,'dd/mm/yyyy:hh24:mi:ss')", VALEUR, TYPE_MES, FREQ_MES)
la commande suivante:Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24 "51950";"05/04/2006 00:15:00";"1";"M";"Q" "51951";"05/04/2006 00:15:00";"1";"M";"Q" "51952";"05/04/2006 00:15:00";"1";"M";"Q" "51953";"05/04/2006 00:15:00";"1";"M";"Q" "52516";"05/04/2006 00:15:00";"1";"M";"Q" "52517";"05/04/2006 00:15:00";"1";"M";"Q" "52518";"05/04/2006 00:15:00";"1";"M";"Q" "53288";"05/04/2006 00:15:00";"1";"M";"Q" "53289";"05/04/2006 00:15:00";"1";"M";"Q" "53290";"05/04/2006 00:15:00";"1";"M";"Q" "53291";"05/04/2006 00:15:00";"1";"M";"Q" "53292";"05/04/2006 00:15:00";"1";"M";"Q" "53293";"05/04/2006 00:15:00";"-1";"M";"Q" "53294";"05/04/2006 00:15:00";"-1";"M";"Q" "53295";"05/04/2006 00:15:00";"-1";"M";"Q" "53296";"05/04/2006 00:15:00";"-1";"M";"Q" "53297";"05/04/2006 00:15:00";"-1";"M";"Q" "53298";"05/04/2006 00:15:00";"-1";"M";"Q" "53299";"05/04/2006 00:15:00";"-1";"M";"Q" "53301";"05/04/2006 00:15:00";"-1";"M";"Q" "53301";"05/04/2006 00:15:00";"-1";"M";"Q" "53302";"05/04/2006 00:15:00";"-1";"M";"Q" "53303";"05/04/2006 00:15:00";"-1";"M";"Q"
fonctionne:Code:
1
2sqlldr control=matable.ctl log=mt.log bad=mt.bat discard=mt.dis errors=0 userid=test/test
Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53 SQL*Loader: Release 10.2.0.1.0 - Production on Wed May 3 10:27:58 2006 Copyright (c) 1982, 2005, Oracle. All rights reserved. Control File: matable.ctl Data File: matable.csv Bad File: mt.bat Discard File: mt.dis (Allow all discards) Number to load: ALL Number to skip: 0 Errors allowed: 0 Bind array: 64 rows, maximum of 256000 bytes Continuation: none specified Path used: Conventional Table MATABLE, loaded from every logical record. Insert option in effect for this table: TRUNCATE Column Name Position Len Term Encl Datatype ------------------------------ ---------- ----- ---- ---- --------------------- ID_MES FIRST * ; O(") CHARACTER DATE_MES NEXT * ; O(") CHARACTER SQL string for column : "to_date(:date_mes,'dd/mm/yyyy:hh24:mi:ss')" VALEUR NEXT * ; O(") CHARACTER TYPE_MES NEXT * ; O(") CHARACTER FREQ_MES NEXT * ; O(") CHARACTER Table MATABLE: 23 Rows successfully loaded. 0 Rows not loaded due to data errors. 0 Rows not loaded because all WHEN clauses were failed. 0 Rows not loaded because all fields were null. Space allocated for bind array: 82560 bytes(64 rows) Read buffer bytes: 1048576 Total logical records skipped: 0 Total logical records read: 23 Total logical records rejected: 0 Total logical records discarded: 0 Run began on Wed May 03 10:27:58 2006 Run ended on Wed May 03 10:27:58 2006 Elapsed time was: 00:00:00.07 CPU time was: 00:00:00.03