@@ -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