-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathvirtload.sh
executable file
·92 lines (65 loc) · 2.29 KB
/
virtload.sh
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
#!/bin/bash
virt_isql="$(dirname $0)/isql"
unzip_source=$1
virt_graphName=$2
virt_port=$3
virt_userName=$4
virt_passWord=$5
# Usage: sourceFile graphName port userName passWord
# e.g. <cmd> myfile.n3.bzip2 http://mygraph.org 1115 dba dba
unzip_extension=${unzip_source##*.}
unzip_target=${unzip_source%.*}
# Phase 1: Unzip
#echo "Target: $unzip_target, Extension: $unzip_extension"
if [ $unzip_extension = "bz2" ]; then
bzip2 -dk $unzip_source
elif [ $unzip_extension = "gz" ]; then
gzip -d $unzip_source
elif [ $unzip_extension = "zip" ]; then
unzip $unzip_source
else
unzip_target=$unzip_source
fi
# Phase 2: Convert to n-triple
# FIXME Skip this step if the source file is already in n-triples format
rapper_source=$unzip_target
rapper_extension=${rapper_source##*.}
rapper_target="${rapper_source%.*}.nt"
if [ $rapper_extension != "nt" ]; then
rapper_target=`mktemp`
rapper_target="$rapper_target.nt"
echo "Converting to n-triples. File is $rapper_target"
rapper $rapper_source -i guess -o ntriples >> $rapper_target
fi
#echo "Unzip target= $unzip_target"
split_size=$(stat -c%s "$rapper_target")
echo "Size = $split_size"
if [ $split_size -gt 5000000 ]; then
echo "File is large."
# Phase 3: Split
split_source=$rapper_target
split_dir=`mktemp -d`
echo "Performing split on file $split_source"
split -a 10 -l 50000 $split_source "${split_dir}/file"
# Phase 4: Load
echo "creating load statement"
for file in `ls $split_dir`
do
load_target="$split_dir/$file"
load_query="EXEC=TTLP_MT(file_to_string_output('$load_target'), '', '$virt_graphName', 255);"
$virt_isql "$virt_port" "$virt_userName" "$virt_passWord" "$load_query"
# echo "$virt_isql" "$virt_port" "$virt_userName" "$virt_passWord" "$load_query"
done;
echo "done"
else
echo "File is small. Loading directly."
load_source=$rapper_target
load_target=`mktemp`
# NOTE By default virtuoso restricts access to files to only explicitely
# allowed directories. By default /tmp is allowed, therefore we copy the
# file there.
cp $load_source $load_target
load_query="EXEC=TTLP_MT(file_to_string_output('$load_target'), '', '$virt_graphName', 255)"
echo "$virt_isql $virt_port $virt_userName $virt_passWord $load_query"
$virt_isql "$virt_port" "$virt_userName" "$virt_passWord" "$load_query"
fi