| 1 | #include "duckdb/parser/query_node/select_node.hpp" | 
|---|---|
| 2 | #include "duckdb/parser/expression_util.hpp" | 
| 3 | |
| 4 | using namespace duckdb; | 
| 5 | using namespace std; | 
| 6 | |
| 7 | bool SelectNode::Equals(const QueryNode *other_) const { | 
| 8 | if (!QueryNode::Equals(other_)) { | 
| 9 | return false; | 
| 10 | } | 
| 11 | if (this == other_) { | 
| 12 | return true; | 
| 13 | } | 
| 14 | auto other = (SelectNode *)other_; | 
| 15 | |
| 16 | // SELECT | 
| 17 | if (!ExpressionUtil::ListEquals(select_list, other->select_list)) { | 
| 18 | return false; | 
| 19 | } | 
| 20 | // FROM | 
| 21 | if (from_table) { | 
| 22 | // we have a FROM clause, compare to the other one | 
| 23 | if (!from_table->Equals(other->from_table.get())) { | 
| 24 | return false; | 
| 25 | } | 
| 26 | } else if (other->from_table) { | 
| 27 | // we don't have a FROM clause, if the other statement has one they are | 
| 28 | // not equal | 
| 29 | return false; | 
| 30 | } | 
| 31 | // WHERE | 
| 32 | if (!BaseExpression::Equals(where_clause.get(), other->where_clause.get())) { | 
| 33 | return false; | 
| 34 | } | 
| 35 | // GROUP BY | 
| 36 | if (!ExpressionUtil::ListEquals(groups, other->groups)) { | 
| 37 | return false; | 
| 38 | } | 
| 39 | |
| 40 | // HAVING | 
| 41 | if (!BaseExpression::Equals(having.get(), other->having.get())) { | 
| 42 | return false; | 
| 43 | } | 
| 44 | return true; | 
| 45 | } | 
| 46 | |
| 47 | unique_ptr<QueryNode> SelectNode::Copy() { | 
| 48 | auto result = make_unique<SelectNode>(); | 
| 49 | for (auto &child : select_list) { | 
| 50 | result->select_list.push_back(child->Copy()); | 
| 51 | } | 
| 52 | result->from_table = from_table ? from_table->Copy() : nullptr; | 
| 53 | result->where_clause = where_clause ? where_clause->Copy() : nullptr; | 
| 54 | // groups | 
| 55 | for (auto &group : groups) { | 
| 56 | result->groups.push_back(group->Copy()); | 
| 57 | } | 
| 58 | result->having = having ? having->Copy() : nullptr; | 
| 59 | this->CopyProperties(*result); | 
| 60 | return move(result); | 
| 61 | } | 
| 62 | |
| 63 | void SelectNode::Serialize(Serializer &serializer) { | 
| 64 | QueryNode::Serialize(serializer); | 
| 65 | // select_list | 
| 66 | serializer.WriteList(select_list); | 
| 67 | // from clause | 
| 68 | serializer.WriteOptional(from_table); | 
| 69 | // where_clause | 
| 70 | serializer.WriteOptional(where_clause); | 
| 71 | // group by / having | 
| 72 | serializer.WriteList(groups); | 
| 73 | serializer.WriteOptional(having); | 
| 74 | } | 
| 75 | |
| 76 | unique_ptr<QueryNode> SelectNode::Deserialize(Deserializer &source) { | 
| 77 | auto result = make_unique<SelectNode>(); | 
| 78 | // select_list | 
| 79 | source.ReadList<ParsedExpression>(result->select_list); | 
| 80 | // from clause | 
| 81 | result->from_table = source.ReadOptional<TableRef>(); | 
| 82 | // where_clause | 
| 83 | result->where_clause = source.ReadOptional<ParsedExpression>(); | 
| 84 | // group by / having | 
| 85 | source.ReadList<ParsedExpression>(result->groups); | 
| 86 | result->having = source.ReadOptional<ParsedExpression>(); | 
| 87 | return move(result); | 
| 88 | } | 
| 89 | 
