Skip to content

Commit

Permalink
fix metadata reload and add dict_get tests
Browse files Browse the repository at this point in the history
  • Loading branch information
zclllyybb committed Dec 31, 2024
1 parent 5dce783 commit ffd052c
Show file tree
Hide file tree
Showing 5 changed files with 132 additions and 15 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -86,8 +86,12 @@ public Pair<FunctionSignature, Dictionary> customSignatureDict() {
Dictionary dictionary;
try {
dictionary = dicMgr.getDictionary(dbName, dictName);
// check is not key column
if (dictionary.getDicColumns().stream().anyMatch(col -> col.getName().equals(colName) && col.isKey())) {
throw new AnalysisException("Can't ask for key " + colName + " by dict_get()");
}
} catch (DdlException e) {
throw new AnalysisException("Dictionary " + dictName + " not found in database " + dbName);
throw new AnalysisException(e.getMessage());
}

return Pair.of(FunctionSignature.ret(dictionary.getColumnType(colName))
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,15 +18,21 @@
package org.apache.doris.nereids.trees.plans.commands.info;

import org.apache.doris.catalog.Type;
import org.apache.doris.common.io.Text;
import org.apache.doris.common.io.Writable;
import org.apache.doris.persist.gson.GsonUtils;

import com.aliyun.datalake20200710.external.google.gson.annotations.SerializedName;
import com.google.gson.annotations.SerializedName;

import java.io.DataInput;
import java.io.DataOutput;
import java.io.IOException;
import java.util.Objects;

/**
* Definition of a dictionary column.
*/
public class DictionaryColumnDefinition {
public class DictionaryColumnDefinition implements Writable {
@SerializedName(value = "name")
private final String name;

Expand All @@ -41,6 +47,12 @@ public DictionaryColumnDefinition(String name, boolean isKey) {
this.isKey = isKey;
}

public DictionaryColumnDefinition(String name, boolean isKey, Type type) {
this.name = Objects.requireNonNull(name, "Column name cannot be null");
this.isKey = isKey;
this.type = type;
}

public String getName() {
return name;
}
Expand All @@ -56,4 +68,15 @@ public Type getType() {
public void setType(Type type) {
this.type = type;
}

@Override
public void write(DataOutput out) throws IOException {
String json = GsonUtils.GSON.toJson(this);
Text.writeString(out, json);
}

public static DictionaryColumnDefinition read(DataInput in) throws IOException {
String json = Text.readString(in);
return GsonUtils.GSON.fromJson(json, DictionaryColumnDefinition.class);
}
}
82 changes: 82 additions & 0 deletions regression-test/suites/dictionary_p0/test_dict_get.groovy
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.

suite("test_dict_get") {
sql "drop database if exists test_dictionary_function"
sql "create database test_dictionary_function"
sql "use test_dictionary_function"

sql """
create table dc(
k0 datetime(6) not null,
k1 varchar not null
)
DISTRIBUTED BY HASH(`k0`) BUCKETS auto
properties("replication_num" = "1");
"""
sql """insert into dc values('2020-12-12', 'abc');"""

sql """
create dictionary dic1 using dc
(
k0 KEY,
k1 VALUE
)
LAYOUT(HASH_MAP);
"""
explain {
sql """select dict_get("test_dictionary_function.dic1", "k1", "2020-12-12")"""
verbose true
notContains "type=datetimev2(6)"
contains "type=varchar(65533)"
}
test {
sql """select dict_get("test_dictionary_function.dic1", "k0", "2020-12-12")"""
exception "Can't ask for key k0 by dict_get()"
}

sql """
create dictionary dic2 using dc
(
k1 KEY,
k0 VALUE
)
LAYOUT(HASH_MAP);
"""
explain {
sql """select dict_get("test_dictionary_function.dic2", "k0", "abc")"""
verbose true
contains "type=datetimev2(6)"
notContains "type=varchar(65533)"
}


sql """
create dictionary dic_ip_trie using dc
(
k1 KEY,
k0 VALUE
)
LAYOUT(IP_TRIE);
"""
explain {
sql """select dict_get("test_dictionary_function.dic_ip_trie", "k0", "abc")"""
verbose true
contains "type=datetimev2(6)"
notContains "type=varchar(65533)"
}
}
24 changes: 12 additions & 12 deletions regression-test/suites/dictionary_p0/upgrade/load.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,9 @@ suite('load', 'p0,restart_fe') {
// 创建用于IP_TRIE字典的基表
sql """
create table ip_base(
ip varchar(32) null,
region varchar(64) null,
isp varchar(32) null
ip varchar(32) not null,
region varchar(64) not null,
isp varchar(32) not null
)
DISTRIBUTED BY HASH(`ip`) BUCKETS auto
properties("replication_num" = "1");
Expand All @@ -34,9 +34,9 @@ suite('load', 'p0,restart_fe') {
// 创建用于HASH_MAP字典的基表
sql """
create table user_base(
user_id varchar(32) null,
user_name varchar(64) null,
age int null
user_id varchar(32) not null,
user_name varchar(64) not null,
age int not null
)
DISTRIBUTED BY HASH(`user_id`) BUCKETS auto
properties("replication_num" = "1");
Expand Down Expand Up @@ -65,9 +65,9 @@ suite('load', 'p0,restart_fe') {
// 增加第三个基表(IP_TRIE)
sql """
create table area_base(
area_ip varchar(32) null,
city varchar(64) null,
country varchar(32) null
area_ip varchar(32) not null,
city varchar(64) not null,
country varchar(32) not null
)
DISTRIBUTED BY HASH(`area_ip`) BUCKETS auto
properties("replication_num" = "1");
Expand All @@ -76,9 +76,9 @@ suite('load', 'p0,restart_fe') {
// 增加第四个基表(HASH_MAP)
sql """
create table product_base(
product_id varchar(32) null,
product_name varchar(64) null,
price decimal(10,2) null
product_id varchar(32) not null,
product_name varchar(64) not null,
price decimal(10,2) not null
)
DISTRIBUTED BY HASH(`product_id`) BUCKETS auto
properties("replication_num" = "1");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,4 +33,12 @@
dict_res.each { row ->
assertTrue(row[2] == "NORMAL")
}

// 验证函数可用
expalin {
sql "select dict_get('test_dictionary_upgrade.area_dict', 'city', 'abc')"
verbose true
contains "varchar(64)"
notContains "varchar(32)"
}
}

0 comments on commit ffd052c

Please sign in to comment.