-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathdatabase
More file actions
109 lines (81 loc) · 2.04 KB
/
database
File metadata and controls
109 lines (81 loc) · 2.04 KB
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
#: /usr/bin/bash
clear
cd
#chmod +x create Delete displayColumns drop droptable insert metaAndData newS newS3 newtable select_ update
PS3="What do you want to do? "
validate_DB_name() {
local name="$1"
if . newS "$name"; then
return 0 # Validation successful
else
return 1 # Validation failed
fi
}
db_directory="$HOME/DB"
# Check if the directory already exists
if [ ! -d "$db_directory" ]; then
# Create the directory
mkdir -p "$db_directory"
fi
cd $db_directory
while true; do
select options in "Create database" "Connect database" "List database" "Remove database" "exit"
do
case $options in
"Create database")
boolean_flag=true
while $boolean_flag;do
read -p "Enter database name: " name
if ! validate_DB_name "$name"; then #check if DB name valid
echo "Invalid DB name! Please enter a valid name for DB."
# ((i--)) # Decrement i to re-prompt for the same column
continue
fi
if [ -d $db_directory/$name ];then #check if this database exists
echo "This database already exists"
else
boolean_flag=false
mkdir $db_directory/$name
echo "Database created successfully"
fi
done
break
;;
"Connect database")
ls $db_directory
read -p "Enter database name: " name
if [ -d $db_directory/$name ];then
source newtable
else
echo "No such database"
fi
break
;;
"List database")
if [ -d $db_directory ];then
ls -p $db_directory | grep / #list only directories
else
echo "No databases created"
fi
break
;;
"Remove database")
ls $db_directory
read -p "Enter database name: " name
if [ -d $db_directory/$name ];then
echo "press 'y' to remove"
rm -rfI $db_directory/$name
echo "Database removed successfully"
else
echo "No such database"
fi
break
;;
"exit")
exit
;;
*)
echo "Choose a valid option"
esac
done
done