Skip to content

Commit fc6f7aa

Browse files
committed
Merge remote-tracking branch 'origin/dev' into dev
2 parents 30210e7 + 1d11052 commit fc6f7aa

File tree

22 files changed

+271
-21
lines changed

22 files changed

+271
-21
lines changed

chat2db-client/src/blocks/DatabaseTableEditor/ColumnList/index.tsx

Lines changed: 1 addition & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -503,18 +503,7 @@ const ColumnList = forwardRef((props: IProps, ref: ForwardedRef<IColumnListRef>)
503503
)}
504504
{editingConfig?.supportDefaultValue && (
505505
<Form.Item labelCol={labelCol} label={i18n('editTable.label.defaultValue')} name="defaultValue">
506-
<CustomSelect
507-
options={[
508-
{
509-
label: 'EMPTY_STRING',
510-
value: 'EMPTY_STRING',
511-
},
512-
{
513-
label: 'NULL',
514-
value: 'NULL',
515-
},
516-
]}
517-
/>
506+
<CustomSelect options={databaseSupportField.defaultValues} />
518507
</Form.Item>
519508
)}
520509
{editingConfig?.supportCharset && (

chat2db-client/src/blocks/DatabaseTableEditor/index.tsx

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -54,6 +54,7 @@ export interface IDatabaseSupportField {
5454
charsets: IOption[];
5555
collations: IOption[];
5656
indexTypes: IOption[];
57+
defaultValues: IOption[];
5758
}
5859

5960
export default memo((props: IProps) => {
@@ -93,6 +94,7 @@ export default memo((props: IProps) => {
9394
charsets: [],
9495
collations: [],
9596
indexTypes: [],
97+
defaultValues: [],
9698
});
9799
const [isLoading, setIsLoading] = useState<boolean>(false);
98100

@@ -148,11 +150,20 @@ export default memo((props: IProps) => {
148150
};
149151
}) || [];
150152

153+
const defaultValues =
154+
res?.defaultValues?.map((i) => {
155+
return {
156+
value: i.defaultValue,
157+
label: i.defaultValue,
158+
};
159+
}) || [];
160+
151161
setDatabaseSupportField({
152162
columnTypes,
153163
charsets,
154164
collations,
155165
indexTypes,
166+
defaultValues,
156167
});
157168
});
158169
}

chat2db-client/src/typings/database.ts

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -51,6 +51,7 @@ export interface IDatabaseSupportField {
5151
charsets: ICharset[];
5252
collations: ICollation[];
5353
indexTypes: IIndexTypes[];
54+
defaultValues: IDefaultValue[];
5455
}
5556

5657
/** 字段所对应的 字符集*/
@@ -84,3 +85,8 @@ export interface IColumnTypes {
8485
supportValue: boolean; // 是否支持值
8586
supportUnit: boolean; // 是否支持单位
8687
}
88+
89+
/** 不同数据库支持不同的默认值 */
90+
export interface IDefaultValue {
91+
defaultValue: string; // 默认值
92+
}

chat2db-server/chat2db-plugins/chat2db-db2/src/main/java/ai/chat2db/plugin/db2/DB2MetaData.java

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,7 @@
88

99
import ai.chat2db.plugin.db2.builder.DB2SqlBuilder;
1010
import ai.chat2db.plugin.db2.type.DB2ColumnTypeEnum;
11+
import ai.chat2db.plugin.db2.type.DB2DefaultValueEnum;
1112
import ai.chat2db.plugin.db2.type.DB2IndexTypeEnum;
1213
import ai.chat2db.spi.MetaData;
1314
import ai.chat2db.spi.SqlBuilder;
@@ -152,6 +153,7 @@ public TableMeta getTableMeta(String databaseName, String schemaName, String tab
152153
.charsets(Lists.newArrayList())
153154
.collations(Lists.newArrayList())
154155
.indexTypes(DB2IndexTypeEnum.getIndexTypes())
156+
.defaultValues(DB2DefaultValueEnum.getDefaultValues())
155157
.build();
156158
}
157159

Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
package ai.chat2db.plugin.db2.type;
2+
3+
import ai.chat2db.spi.model.DefaultValue;
4+
5+
import java.util.Arrays;
6+
import java.util.List;
7+
8+
public enum DB2DefaultValueEnum {
9+
EMPTY_STRING("EMPTY_STRING"),
10+
NULL("NULL"),
11+
;
12+
private DefaultValue defaultValue;
13+
14+
DB2DefaultValueEnum(String defaultValue) {
15+
this.defaultValue = new DefaultValue(defaultValue);
16+
}
17+
18+
19+
public DefaultValue getDefaultValue() {
20+
return defaultValue;
21+
}
22+
23+
public static List<DefaultValue> getDefaultValues() {
24+
return Arrays.stream(DB2DefaultValueEnum.values()).map(DB2DefaultValueEnum::getDefaultValue).collect(java.util.stream.Collectors.toList());
25+
}
26+
27+
}

chat2db-server/chat2db-plugins/chat2db-dm/src/main/java/ai/chat2db/plugin/dm/DMMetaData.java

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,7 @@
88

99
import ai.chat2db.plugin.dm.builder.DMSqlBuilder;
1010
import ai.chat2db.plugin.dm.type.DMColumnTypeEnum;
11+
import ai.chat2db.plugin.dm.type.DMDefaultValueEnum;
1112
import ai.chat2db.plugin.dm.type.DMIndexTypeEnum;
1213
import ai.chat2db.spi.MetaData;
1314
import ai.chat2db.spi.SqlBuilder;
@@ -218,6 +219,7 @@ public TableMeta getTableMeta(String databaseName, String schemaName, String tab
218219
.charsets(Lists.newArrayList())
219220
.collations(Lists.newArrayList())
220221
.indexTypes(DMIndexTypeEnum.getIndexTypes())
222+
.defaultValues(DMDefaultValueEnum.getDefaultValues())
221223
.build();
222224
}
223225

Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
package ai.chat2db.plugin.dm.type;
2+
3+
import ai.chat2db.spi.model.DefaultValue;
4+
5+
import java.util.Arrays;
6+
import java.util.List;
7+
8+
public enum DMDefaultValueEnum {
9+
EMPTY_STRING("EMPTY_STRING"),
10+
NULL("NULL"),
11+
;
12+
private DefaultValue defaultValue;
13+
14+
DMDefaultValueEnum(String defaultValue) {
15+
this.defaultValue = new DefaultValue(defaultValue);
16+
}
17+
18+
19+
public DefaultValue getDefaultValue() {
20+
return defaultValue;
21+
}
22+
23+
public static List<DefaultValue> getDefaultValues() {
24+
return Arrays.stream(DMDefaultValueEnum.values()).map(DMDefaultValueEnum::getDefaultValue).collect(java.util.stream.Collectors.toList());
25+
}
26+
27+
}

chat2db-server/chat2db-plugins/chat2db-kingbase/src/main/java/ai/chat2db/plugin/kingbase/KingBaseMetaData.java

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,7 @@
22

33
import ai.chat2db.plugin.kingbase.builder.KingBaseSqlBuilder;
44
import ai.chat2db.plugin.kingbase.type.KingBaseColumnTypeEnum;
5+
import ai.chat2db.plugin.kingbase.type.KingBaseDefaultValueEnum;
56
import ai.chat2db.plugin.kingbase.type.KingBaseIndexTypeEnum;
67
import ai.chat2db.spi.MetaData;
78
import ai.chat2db.spi.SqlBuilder;
@@ -196,6 +197,7 @@ public TableMeta getTableMeta(String databaseName, String schemaName, String tab
196197
//.charsets(PostgreSQLCharsetEnum.getCharsets())
197198
//.collations(PostgreSQLCollationEnum.getCollations())
198199
.indexTypes(KingBaseIndexTypeEnum.getIndexTypes())
200+
.defaultValues(KingBaseDefaultValueEnum.getDefaultValues())
199201
.build();
200202
}
201203
@Override
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
package ai.chat2db.plugin.kingbase.type;
2+
3+
import ai.chat2db.spi.model.DefaultValue;
4+
5+
import java.util.Arrays;
6+
import java.util.List;
7+
8+
public enum KingBaseDefaultValueEnum {
9+
EMPTY_STRING("EMPTY_STRING"),
10+
NULL("NULL"),
11+
;
12+
private DefaultValue defaultValue;
13+
14+
KingBaseDefaultValueEnum(String defaultValue) {
15+
this.defaultValue = new DefaultValue(defaultValue);
16+
}
17+
18+
19+
public DefaultValue getDefaultValue() {
20+
return defaultValue;
21+
}
22+
23+
public static List<DefaultValue> getDefaultValues() {
24+
return Arrays.stream(KingBaseDefaultValueEnum.values()).map(KingBaseDefaultValueEnum::getDefaultValue).collect(java.util.stream.Collectors.toList());
25+
}
26+
27+
}

chat2db-server/chat2db-plugins/chat2db-mysql/src/main/java/ai/chat2db/plugin/mysql/MysqlMetaData.java

Lines changed: 2 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -8,10 +8,7 @@
88
import java.util.stream.Stream;
99

1010
import ai.chat2db.plugin.mysql.builder.MysqlSqlBuilder;
11-
import ai.chat2db.plugin.mysql.type.MysqlCharsetEnum;
12-
import ai.chat2db.plugin.mysql.type.MysqlCollationEnum;
13-
import ai.chat2db.plugin.mysql.type.MysqlColumnTypeEnum;
14-
import ai.chat2db.plugin.mysql.type.MysqlIndexTypeEnum;
11+
import ai.chat2db.plugin.mysql.type.*;
1512
import ai.chat2db.spi.MetaData;
1613
import ai.chat2db.spi.SqlBuilder;
1714
import ai.chat2db.spi.ValueHandler;
@@ -287,6 +284,7 @@ public TableMeta getTableMeta(String databaseName, String schemaName, String tab
287284
.charsets(MysqlCharsetEnum.getCharsets())
288285
.collations(MysqlCollationEnum.getCollations())
289286
.indexTypes(MysqlIndexTypeEnum.getIndexTypes())
287+
.defaultValues(MysqlDefaultValueEnum.getDefaultValues())
290288
.build();
291289
}
292290

0 commit comments

Comments
 (0)