Skip to content

Commit 4542774

Browse files
committed
feat: modify template
1 parent fe44882 commit 4542774

File tree

1 file changed

+28
-15
lines changed

1 file changed

+28
-15
lines changed

backend/template.yaml

Lines changed: 28 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -4,9 +4,18 @@ template:
44
### 请使用语言:{lang} 回答,若有深度思考过程,则思考过程也需要使用 {lang} 输出
55
66
任务:
7-
根据表结构和问题生成符合{engine}数据库引擎规范的sql语句,以及sql中所用到的表名(不要包含schema和database,用数组返回)。
7+
根据给定的表结构(M-Schema)和用户问题生成符合{engine}数据库引擎规范的sql语句,以及sql中所用到的表名(不要包含schema和database,用数组返回)。
88
你必须遵守以下规则:
99
- 生成的SQL必须符合{engine}的规范。
10+
- 你的回答必须使用如下JSON格式返回:
11+
{{"success":true,"sql":"生成的SQL语句","tables":["表名1","表名2",...]}}
12+
- 问题与生成SQL无关时,直接回答:
13+
{{"success":false,"message":"抱歉,我无法回答您的问题。"}}
14+
- 如果根据提供的表结构不能生成符合问题与条件的SQL,回答:
15+
{{"success":false,"message":"无法生成SQL的原因"}}
16+
- 如果问题是图表展示相关且与生成SQL查询无关时,请参考上一次回答的SQL来生成SQL
17+
- 如果问题是图表展示相关,可参考的图表类型为表格(table)、柱状图(column)、条形图(bar)、折线图(line)或饼图(pie),返回的JSON:
18+
{{"success":true,"sql":"生成的SQL语句","chart-type":"选择的图表类型(table/column/bar/line/pie)","tables":["表名1","表名2",...]}}
1019
- 提问中如果有涉及数据源名称或数据源描述的内容,则忽略数据源的信息,直接根据剩余内容生成SQL
1120
- 根据表结构生成SQL语句,需给每个表名生成一个别名(不要加AS)。
1221
- SQL查询中不能使用星号(*),必须明确指定字段名.
@@ -18,35 +27,39 @@ template:
1827
- 如数据库引擎是 MySQL,则在表名、字段名、别名外层加反引号;
1928
- 如数据库引擎是 Microsoft SQL Server,则在schema、表名、字段名、别名外层加方括号。
2029
- 以PostgreSQL为例,查询Schema为TEST表TABLE下所有数据,则生成的SQL为:
21-
SELECT * FROM "TEST"."TABLE"
30+
SELECT "id" FROM "TEST"."TABLE"
2231
- 注意在表名外双引号的位置,千万不要生成为:
23-
SELECT * FROM "TEST.TABLE"
32+
SELECT "id" FROM "TEST.TABLE"
2433
- 如果生成SQL的字段内有时间格式的字段(重要):
2534
- 若提问中没有指定查询顺序,则默认按时间升序排序
2635
- 若提问是时间,且没有指定具体格式,则格式化为yyyy-MM-dd HH:mm:ss的格式
2736
- 若提问是日期,且没有指定具体格式,则格式化为yyyy-MM-dd的格式
2837
- 若提问是年月,且没有指定具体格式,则格式化为yyyy-MM的格式
2938
- 若提问是年,且没有指定具体格式,则格式化为yyyy的格式
3039
- 生成的格式化语法需要适配对应的数据库引擎。
31-
- 生成的SQL使用JSON格式返回:
32-
{{"success":true,"sql":"生成的SQL语句","tables":["表名1","表名2",...]}}
33-
- 问题与生成SQL无关时,直接回答:
34-
{{"success":false,"message":"抱歉,我无法回答您的问题。"}}
35-
- 如果根据提供的表结构不能生成符合问题与条件的SQL,回答:
36-
{{"success":false,"message":"无法生成SQL的原因"}}
37-
- 如果问题是图表展示相关且与生成SQL查询无关时,请参考上一次回答的SQL来生成SQL
38-
- 如果问题是图表展示相关,可参考的图表类型为表格(table)、柱状图(column)、条形图(bar)、折线图(line)或饼图(pie),返回的JSON:
39-
{{"success":true,"sql":"生成的SQL语句","chart-type":"选择的图表类型(table/column/bar/line/pie)","tables":["表名1","表名2",...]}}
4040
- 生成的SQL查询结果可以用来进行图表展示,需要注意排序字段的排序优先级,例如:
4141
- 柱状图或折线图:适合展示在横轴的字段优先排序,若SQL包含分类字段,则分类字段次一级排序
4242
43+
### M-Schema格式简单的解释如下:
44+
```
45+
【DB_ID】 [Database名]
46+
【Schema】
47+
# Table: [Database名].[Table名], [表描述(若没有则为空)]
48+
[
49+
([字段名1]:[字段1的类型], [字段1的描述(这一行的逗号后都是描述,若没有则为空)]),
50+
([字段名2]:[字段2的类型], [字段2的描述(这一行的逗号后都是描述,若没有则为空)]),
51+
([字段名3]:[字段3的类型], [字段3的描述(这一行的逗号后都是描述,若没有则为空)]),
52+
...
53+
]
54+
```
55+
56+
### 提供表结构如下:
57+
{schema}
58+
4359
### 响应, 请直接返回JSON结果:
4460
```json
4561
4662
user: |
47-
### 表结构:
48-
{schema}
49-
5063
### 问题:
5164
{question}
5265

0 commit comments

Comments
 (0)