瀏覽代碼

LibSQL: First cut of SQL `WHERE` clause

Filters matching rows by doing a table scan and evaluating the `WHERE`
expression for every row.

Does not use indexes, for one because they do not exist yet.
Jan de Visser 3 年之前
父節點
當前提交
0cfb5eec32
共有 1 個文件被更改,包括 7 次插入1 次删除
  1. 7 1
      Userland/Libraries/LibSQL/AST/Select.cpp

+ 7 - 1
Userland/Libraries/LibSQL/AST/Select.cpp

@@ -34,9 +34,15 @@ RefPtr<SQLResult> Select::execute(ExecutionContext& context) const
         }
         }
         context.result = SQLResult::construct();
         context.result = SQLResult::construct();
         AK::NonnullRefPtr<TupleDescriptor> descriptor = AK::adopt_ref(*new TupleDescriptor);
         AK::NonnullRefPtr<TupleDescriptor> descriptor = AK::adopt_ref(*new TupleDescriptor);
+        Tuple tuple(descriptor);
         for (auto& row : context.database->select_all(*table)) {
         for (auto& row : context.database->select_all(*table)) {
             context.current_row = &row;
             context.current_row = &row;
-            Tuple tuple(descriptor);
+            if (where_clause()) {
+                auto where_result = where_clause()->evaluate(context);
+                if (!where_result)
+                    continue;
+            }
+            tuple.clear();
             for (auto& col : columns) {
             for (auto& col : columns) {
                 auto value = col.expression()->evaluate(context);
                 auto value = col.expression()->evaluate(context);
                 tuple.append(value);
                 tuple.append(value);