sqlmig: support chemin config/sqlmig et bug avec csv_null
This commit is contained in:
parent
45da726704
commit
01325d0c23
18
sqlmig
18
sqlmig
|
@ -980,6 +980,8 @@ if [ -z "$dbdir" -a -z "$updatedir" ]; then
|
||||||
setx parentdir=dirname -- "$cwd"
|
setx parentdir=dirname -- "$cwd"
|
||||||
if __check_devel_dir src/main/resources/database; then
|
if __check_devel_dir src/main/resources/database; then
|
||||||
enote "Autosélection src/main/resources/database/"
|
enote "Autosélection src/main/resources/database/"
|
||||||
|
elif __check_devel_dir config/sqlmig; then
|
||||||
|
enote "Autosélection config/sqlmig/"
|
||||||
elif __check_devel_dir support/database; then
|
elif __check_devel_dir support/database; then
|
||||||
enote "Autosélection support/database/"
|
enote "Autosélection support/database/"
|
||||||
elif __check_devel_dir database; then
|
elif __check_devel_dir database; then
|
||||||
|
@ -1086,7 +1088,8 @@ grant resource to $dbname;"
|
||||||
echo >"$dbdir/ora.conf" "\
|
echo >"$dbdir/ora.conf" "\
|
||||||
# Paramètres de connexion par défaut
|
# Paramètres de connexion par défaut
|
||||||
ORACLE_SID=orcl
|
ORACLE_SID=orcl
|
||||||
NLS_LANG=AMERICAN_AMERICA.AL32UTF8
|
NLS_LANG=FRENCH_FRANCE.AL32UTF8
|
||||||
|
#NLS_LANG=AMERICAN_AMERICA.AL32UTF8
|
||||||
# paramètres de connexion pour les mises à jour administratives
|
# paramètres de connexion pour les mises à jour administratives
|
||||||
# si aucune valeur n'est spécifiée, la valeur effective est '/ as sysdba' mais
|
# si aucune valeur n'est spécifiée, la valeur effective est '/ as sysdba' mais
|
||||||
# cela requière que la mise à jour soit faite avec une connexion locale.
|
# cela requière que la mise à jour soit faite avec une connexion locale.
|
||||||
|
@ -1334,9 +1337,14 @@ for dbdir in "${dbdirs[@]}"; do
|
||||||
ensure_dbtype "$dbdir" "$type"
|
ensure_dbtype "$dbdir" "$type"
|
||||||
ensure_dbmode "$dbtype" "$mode"
|
ensure_dbmode "$dbtype" "$mode"
|
||||||
|
|
||||||
|
if [ -n "$data_csv" ]; then
|
||||||
# Conversion csv --> sql
|
# Conversion csv --> sql
|
||||||
array_lsfiles csvs "$dbdir" "*.csv"
|
array_lsfiles csvs "$dbdir" "*.csv"
|
||||||
if [ "$dbtype" == mysql -a -n "$data_csv" ]; then
|
if [ "$dbtype" == mysql ]; then
|
||||||
|
setx defaults=mysql_get_defaults "$dbdir"
|
||||||
|
set_csv_null=1
|
||||||
|
mysql__mconf_get "$defaults"
|
||||||
|
|
||||||
etitled "Conversion"
|
etitled "Conversion"
|
||||||
for csv in "${csvs[@]}"; do
|
for csv in "${csvs[@]}"; do
|
||||||
setx csvname=basename -- "$csv"
|
setx csvname=basename -- "$csv"
|
||||||
|
@ -1346,7 +1354,7 @@ for dbdir in "${dbdirs[@]}"; do
|
||||||
fi
|
fi
|
||||||
|
|
||||||
estep "$csvname --> ${csvname%.csv}.sql"
|
estep "$csvname --> ${csvname%.csv}.sql"
|
||||||
eval "$(awk '{
|
script='{
|
||||||
truncate = ($0 ~ /-data_truncate(.devel)?.csv$/)? "1": ""
|
truncate = ($0 ~ /-data_truncate(.devel)?.csv$/)? "1": ""
|
||||||
sub(/^.*\//, "")
|
sub(/^.*\//, "")
|
||||||
sub(/^[A-Z0-9.]*[0-9]-?/, "")
|
sub(/^[A-Z0-9.]*[0-9]-?/, "")
|
||||||
|
@ -1356,11 +1364,13 @@ for dbdir in "${dbdirs[@]}"; do
|
||||||
print "truncate=" truncate
|
print "truncate=" truncate
|
||||||
gsub(/'\''/, "'\'\\\\\'\''")
|
gsub(/'\''/, "'\'\\\\\'\''")
|
||||||
print "table='\''" $0 "'\''"
|
print "table='\''" $0 "'\''"
|
||||||
}' <<<"$csvname")" #"
|
}'
|
||||||
|
eval "$(awk "$script" <<<"$csvname")"
|
||||||
"$scriptdir/mysqlloadcsv" >"$sql" ${truncate:+-T} -Z "$csv_null" -nIf "$csv" "$table" --prefix "-- -*- coding: utf-8 mode: sql -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8"
|
"$scriptdir/mysqlloadcsv" >"$sql" ${truncate:+-T} -Z "$csv_null" -nIf "$csv" "$table" --prefix "-- -*- coding: utf-8 mode: sql -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8"
|
||||||
done
|
done
|
||||||
eend; eclearp
|
eend; eclearp
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
# lister les mises à jour disponibles
|
# lister les mises à jour disponibles
|
||||||
drops=()
|
drops=()
|
||||||
|
|
Loading…
Reference in New Issue