This repository has been archived on 2025-04-11. You can view files and clone it, but cannot push or open issues or pull requests.
dmspine64backup/Relation.h
Rebecca Schofield 773544da13 use THIS
2015-09-15 22:20:14 -05:00

93 lines
1.8 KiB
C++
Executable file

#include <iostream>
#include <vector>
#include "Attribute.h"
//Functional
class Relation {
string name; //The title the user gives it
vector<Attribute> att; //A vector of the columns
int size;
public:
Relation(string n, vector<Attribute> a) {
name = n;
att = a;
size = 0;
}
int getSize() { return size; }
void addTuple(vector<string> tuple) {
//Loop through the attribute columns
for(int i = 0; i < att.size(); i++) {
//Loop through the elements in the i'th column
for(int j = 0; j < att[i].values.size(); j++){
//In this column, at this element's spot, assign an element from the tuple vector to this spot
att[i].addRow(tuple[i]);
size++;
}
}
}
void removeTuple(int tupleNum) {
if (tupleNum > att[0].getSize() || tupleNum < 0)
{
cout<<"ERROR! index out of bound"<<endl;
}
else
{
for(int i = 0; i < att.size(); ++i) //for all the attributes
{
att[i].erase(tupleNum);
}
}
}
int getSize() { return size; }
string getTableName() {
return name;
}
void displayTableName() {
cout << "The table name is: " << name << endl;
}
vector<Attribute> getAttributes() {
return att;
}
void projectQuery(string input) {
cout << "-----------Initiated Query Projection---------" << endl;
for(int i = 0; i < att.size(); i++) {
if(att[i].getName() == input) {
cout << "Column Title: " << input << endl;
for(int j = 0; j < att[i].getSize(); j++) {
cout << att[i].values[j] << endl;
}
break;
}
else
cout << "Attribute input not valid" << endl;
}
}
void display() {
cout<<"\n\nDisplay of relation--------------------------------"<<endl;
cout<<"Relation name: "<<name<<endl;
for (int i = 0; i < attributeNames.size(); ++i)
{
cout<<"\nAttribute name: "<<attributeNames[i]<<": ";
att[i].display();
}
}
};