H Kevin Hu commited on
Commit
d3e887e
·
1 Parent(s): 36a516d

Add template text2sql (#1985)

Browse files

### What problem does this PR solve?

#1965

### Type of change

- [x ] New Feature (non-breaking change which adds functionality)

---------

Co-authored-by: Kevin Hu <kevinhu.sh@gmail.com>

Files changed (1) hide show
  1. agent/templates/text2sql.json +439 -0
agent/templates/text2sql.json ADDED
@@ -0,0 +1,439 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "id": 5,
3
+ "title": "Text To SQL",
4
+ "description": "An agent tool provides the ability to convert text questions into SQL statements, you will need to provide 3 kinds of knowledge bases. 1. DDL data for the database. 2. Examples of text questions converted into SQL statements. 3. A description of the database contents, including but not limited to: tables, records, etc... ",
5
+ "canvas_type": "chatbot",
6
+ "dsl": {
7
+ "answer": [],
8
+ "components": {
9
+ "Answer:SocialAdsWonder": {
10
+ "downstream": [
11
+ "Retrieval:WetNewsHunt",
12
+ "Retrieval:OpenWingsRepeat",
13
+ "Retrieval:StrongDrinksShare"
14
+ ],
15
+ "obj": {
16
+ "component_name": "Answer",
17
+ "params": {}
18
+ },
19
+ "upstream": [
20
+ "begin",
21
+ "Generate:OliveDotsInvent"
22
+ ]
23
+ },
24
+ "Generate:OliveDotsInvent": {
25
+ "downstream": [
26
+ "Answer:SocialAdsWonder"
27
+ ],
28
+ "obj": {
29
+ "component_name": "Generate",
30
+ "params": {
31
+ "cite": true,
32
+ "frequency_penalty": 0.7,
33
+ "llm_id": "deepseek-chat",
34
+ "max_tokens": 256,
35
+ "message_history_window_size": 12,
36
+ "parameters": [
37
+ {
38
+ "component_id": "Retrieval:StrongDrinksShare",
39
+ "id": "36c09e33-bad2-42fe-9a56-f136677bb405",
40
+ "key": "ddl_input"
41
+ },
42
+ {
43
+ "component_id": "Retrieval:OpenWingsRepeat",
44
+ "id": "e4cfe15e-64cd-4351-b49e-0da2f5c8ec34",
45
+ "key": "db_input"
46
+ },
47
+ {
48
+ "component_id": "Retrieval:WetNewsHunt",
49
+ "id": "946d8272-fc98-4040-a75f-502df7e4a42e",
50
+ "key": "sql_input"
51
+ }
52
+ ],
53
+ "presence_penalty": 0.4,
54
+ "prompt": "##The user provides a question and you provide SQL. You will only respond with SQL code and not with any explanations.\n\n##Respond with only SQL code. Do not answer with any explanations -- just the code.\n\n##You may use the following DDL statements as a reference for what tables might be available. Use responses to past questions also to guide you: {ddl_input}.\n\n##You may use the following documentation as a reference for what tables might be available. Use responses to past questions also to guide you: {db_input}.\n\n##You may use the following SQL statements as a reference for what tables might be available. Use responses to past questions also to guide you: {sql_input}.",
55
+ "temperature": 0.1,
56
+ "top_p": 0.3
57
+ }
58
+ },
59
+ "upstream": [
60
+ "Retrieval:StrongDrinksShare",
61
+ "Retrieval:WetNewsHunt",
62
+ "Retrieval:OpenWingsRepeat"
63
+ ]
64
+ },
65
+ "Retrieval:OpenWingsRepeat": {
66
+ "downstream": [
67
+ "Generate:OliveDotsInvent"
68
+ ],
69
+ "obj": {
70
+ "component_name": "Retrieval",
71
+ "params": {
72
+ "kb_ids": [
73
+ "0ab5de985ba911efad9942010a8a0006"
74
+ ],
75
+ "keywords_similarity_weight": 0.3,
76
+ "similarity_threshold": 0.2,
77
+ "top_n": 8
78
+ }
79
+ },
80
+ "upstream": [
81
+ "Answer:SocialAdsWonder"
82
+ ]
83
+ },
84
+ "Retrieval:StrongDrinksShare": {
85
+ "downstream": [
86
+ "Generate:OliveDotsInvent"
87
+ ],
88
+ "obj": {
89
+ "component_name": "Retrieval",
90
+ "params": {
91
+ "kb_ids": [
92
+ "b1a6a45e5ba811ef80dc42010a8a0006"
93
+ ],
94
+ "keywords_similarity_weight": 0.1,
95
+ "similarity_threshold": 0.02,
96
+ "top_n": 18
97
+ }
98
+ },
99
+ "upstream": [
100
+ "Answer:SocialAdsWonder"
101
+ ]
102
+ },
103
+ "Retrieval:WetNewsHunt": {
104
+ "downstream": [
105
+ "Generate:OliveDotsInvent"
106
+ ],
107
+ "obj": {
108
+ "component_name": "Retrieval",
109
+ "params": {
110
+ "kb_ids": [
111
+ "31257b925b9f11ef9f0142010a8a0004"
112
+ ],
113
+ "keywords_similarity_weight": 0.3,
114
+ "similarity_threshold": 0.2,
115
+ "top_n": 8
116
+ }
117
+ },
118
+ "upstream": [
119
+ "Answer:SocialAdsWonder"
120
+ ]
121
+ },
122
+ "begin": {
123
+ "downstream": [
124
+ "Answer:SocialAdsWonder"
125
+ ],
126
+ "obj": {
127
+ "component_name": "Begin",
128
+ "params": {}
129
+ },
130
+ "upstream": []
131
+ }
132
+ },
133
+ "graph": {
134
+ "edges": [
135
+ {
136
+ "id": "reactflow__edge-begin-Answer:SocialAdsWonderc",
137
+ "markerEnd": "logo",
138
+ "source": "begin",
139
+ "sourceHandle": null,
140
+ "style": {
141
+ "stroke": "rgb(202 197 245)",
142
+ "strokeWidth": 2
143
+ },
144
+ "target": "Answer:SocialAdsWonder",
145
+ "targetHandle": "c",
146
+ "type": "buttonEdge"
147
+ },
148
+ {
149
+ "id": "reactflow__edge-Answer:SocialAdsWonderb-Retrieval:WetNewsHuntc",
150
+ "markerEnd": "logo",
151
+ "source": "Answer:SocialAdsWonder",
152
+ "sourceHandle": "b",
153
+ "style": {
154
+ "stroke": "rgb(202 197 245)",
155
+ "strokeWidth": 2
156
+ },
157
+ "target": "Retrieval:WetNewsHunt",
158
+ "targetHandle": "c",
159
+ "type": "buttonEdge"
160
+ },
161
+ {
162
+ "id": "reactflow__edge-Answer:SocialAdsWonderb-Retrieval:OpenWingsRepeatc",
163
+ "markerEnd": "logo",
164
+ "source": "Answer:SocialAdsWonder",
165
+ "sourceHandle": "b",
166
+ "style": {
167
+ "stroke": "rgb(202 197 245)",
168
+ "strokeWidth": 2
169
+ },
170
+ "target": "Retrieval:OpenWingsRepeat",
171
+ "targetHandle": "c",
172
+ "type": "buttonEdge"
173
+ },
174
+ {
175
+ "id": "reactflow__edge-Answer:SocialAdsWonderb-Retrieval:StrongDrinksSharec",
176
+ "markerEnd": "logo",
177
+ "source": "Answer:SocialAdsWonder",
178
+ "sourceHandle": "b",
179
+ "style": {
180
+ "stroke": "rgb(202 197 245)",
181
+ "strokeWidth": 2
182
+ },
183
+ "target": "Retrieval:StrongDrinksShare",
184
+ "targetHandle": "c",
185
+ "type": "buttonEdge"
186
+ },
187
+ {
188
+ "id": "reactflow__edge-Retrieval:StrongDrinksShareb-Generate:OliveDotsInventa",
189
+ "markerEnd": "logo",
190
+ "source": "Retrieval:StrongDrinksShare",
191
+ "sourceHandle": "b",
192
+ "style": {
193
+ "stroke": "rgb(202 197 245)",
194
+ "strokeWidth": 2
195
+ },
196
+ "target": "Generate:OliveDotsInvent",
197
+ "targetHandle": "a",
198
+ "type": "buttonEdge"
199
+ },
200
+ {
201
+ "id": "reactflow__edge-Retrieval:WetNewsHuntb-Generate:OliveDotsInventa",
202
+ "markerEnd": "logo",
203
+ "source": "Retrieval:WetNewsHunt",
204
+ "sourceHandle": "b",
205
+ "style": {
206
+ "stroke": "rgb(202 197 245)",
207
+ "strokeWidth": 2
208
+ },
209
+ "target": "Generate:OliveDotsInvent",
210
+ "targetHandle": "a",
211
+ "type": "buttonEdge"
212
+ },
213
+ {
214
+ "id": "reactflow__edge-Retrieval:OpenWingsRepeatb-Generate:OliveDotsInventa",
215
+ "markerEnd": "logo",
216
+ "source": "Retrieval:OpenWingsRepeat",
217
+ "sourceHandle": "b",
218
+ "style": {
219
+ "stroke": "rgb(202 197 245)",
220
+ "strokeWidth": 2
221
+ },
222
+ "target": "Generate:OliveDotsInvent",
223
+ "targetHandle": "a",
224
+ "type": "buttonEdge"
225
+ },
226
+ {
227
+ "id": "reactflow__edge-Generate:OliveDotsInventc-Answer:SocialAdsWonderd",
228
+ "markerEnd": "logo",
229
+ "source": "Generate:OliveDotsInvent",
230
+ "sourceHandle": "c",
231
+ "style": {
232
+ "stroke": "rgb(202 197 245)",
233
+ "strokeWidth": 2
234
+ },
235
+ "target": "Answer:SocialAdsWonder",
236
+ "targetHandle": "d",
237
+ "type": "buttonEdge"
238
+ }
239
+ ],
240
+ "nodes": [
241
+ {
242
+ "data": {
243
+ "label": "Begin",
244
+ "name": "begin"
245
+ },
246
+ "dragging": false,
247
+ "height": 50,
248
+ "id": "begin",
249
+ "position": {
250
+ "x": -398.61441136019056,
251
+ "y": 144.28672563400067
252
+ },
253
+ "positionAbsolute": {
254
+ "x": -398.61441136019056,
255
+ "y": 144.28672563400067
256
+ },
257
+ "selected": false,
258
+ "sourcePosition": "left",
259
+ "targetPosition": "right",
260
+ "type": "beginNode",
261
+ "width": 50
262
+ },
263
+ {
264
+ "data": {
265
+ "form": {},
266
+ "label": "Answer",
267
+ "name": "interface"
268
+ },
269
+ "dragging": false,
270
+ "height": 100,
271
+ "id": "Answer:SocialAdsWonder",
272
+ "position": {
273
+ "x": -271.9289105495367,
274
+ "y": 120.9282206409824
275
+ },
276
+ "positionAbsolute": {
277
+ "x": -271.9289105495367,
278
+ "y": 120.9282206409824
279
+ },
280
+ "selected": false,
281
+ "sourcePosition": "right",
282
+ "targetPosition": "left",
283
+ "type": "logicNode",
284
+ "width": 100
285
+ },
286
+ {
287
+ "data": {
288
+ "form": {
289
+ "kb_ids": [
290
+ "31257b925b9f11ef9f0142010a8a0004"
291
+ ],
292
+ "keywords_similarity_weight": 0.3,
293
+ "similarity_threshold": 0.2,
294
+ "top_n": 8
295
+ },
296
+ "label": "Retrieval",
297
+ "name": "Q->SQL"
298
+ },
299
+ "dragging": false,
300
+ "height": 100,
301
+ "id": "Retrieval:WetNewsHunt",
302
+ "position": {
303
+ "x": -44.1852870981603,
304
+ "y": 130.77161580129524
305
+ },
306
+ "positionAbsolute": {
307
+ "x": -44.1852870981603,
308
+ "y": 130.77161580129524
309
+ },
310
+ "selected": false,
311
+ "sourcePosition": "right",
312
+ "targetPosition": "left",
313
+ "type": "logicNode",
314
+ "width": 100
315
+ },
316
+ {
317
+ "data": {
318
+ "form": {
319
+ "cite": true,
320
+ "frequencyPenaltyEnabled": true,
321
+ "frequency_penalty": 0.7,
322
+ "llm_id": "deepseek-chat",
323
+ "maxTokensEnabled": true,
324
+ "max_tokens": 256,
325
+ "message_history_window_size": 12,
326
+ "parameters": [
327
+ {
328
+ "component_id": "Retrieval:StrongDrinksShare",
329
+ "id": "36c09e33-bad2-42fe-9a56-f136677bb405",
330
+ "key": "ddl_input"
331
+ },
332
+ {
333
+ "component_id": "Retrieval:OpenWingsRepeat",
334
+ "id": "e4cfe15e-64cd-4351-b49e-0da2f5c8ec34",
335
+ "key": "db_input"
336
+ },
337
+ {
338
+ "component_id": "Retrieval:WetNewsHunt",
339
+ "id": "946d8272-fc98-4040-a75f-502df7e4a42e",
340
+ "key": "sql_input"
341
+ }
342
+ ],
343
+ "presencePenaltyEnabled": true,
344
+ "presence_penalty": 0.4,
345
+ "prompt": "##The user provides a question and you provide SQL. You will only respond with SQL code and not with any explanations.\n\n##Respond with only SQL code. Do not answer with any explanations -- just the code.\n\n##You may use the following DDL statements as a reference for what tables might be available. Use responses to past questions also to guide you: {ddl_input}.\n\n##You may use the following documentation as a reference for what tables might be available. Use responses to past questions also to guide you: {db_input}.\n\n##You may use the following SQL statements as a reference for what tables might be available. Use responses to past questions also to guide you: {sql_input}.",
346
+ "temperature": 0.1,
347
+ "temperatureEnabled": true,
348
+ "topPEnabled": true,
349
+ "top_p": 0.3
350
+ },
351
+ "label": "Generate",
352
+ "name": "FuzzyGoatsCover"
353
+ },
354
+ "dragging": false,
355
+ "height": 150,
356
+ "id": "Generate:OliveDotsInvent",
357
+ "position": {
358
+ "x": 127.63574050151522,
359
+ "y": -209.30480702441503
360
+ },
361
+ "positionAbsolute": {
362
+ "x": 127.63574050151522,
363
+ "y": -209.30480702441503
364
+ },
365
+ "selected": true,
366
+ "sourcePosition": "right",
367
+ "targetPosition": "left",
368
+ "type": "logicNode",
369
+ "width": 150
370
+ },
371
+ {
372
+ "data": {
373
+ "form": {
374
+ "kb_ids": [
375
+ "0ab5de985ba911efad9942010a8a0006"
376
+ ],
377
+ "keywords_similarity_weight": 0.3,
378
+ "similarity_threshold": 0.2,
379
+ "top_n": 8
380
+ },
381
+ "label": "Retrieval",
382
+ "name": "DB Description"
383
+ },
384
+ "dragging": false,
385
+ "height": 100,
386
+ "id": "Retrieval:OpenWingsRepeat",
387
+ "position": {
388
+ "x": -44.48969718602855,
389
+ "y": 272.5769102113132
390
+ },
391
+ "positionAbsolute": {
392
+ "x": -44.48969718602855,
393
+ "y": 272.5769102113132
394
+ },
395
+ "selected": false,
396
+ "sourcePosition": "right",
397
+ "targetPosition": "left",
398
+ "type": "logicNode",
399
+ "width": 100
400
+ },
401
+ {
402
+ "data": {
403
+ "form": {
404
+ "kb_ids": [
405
+ "b1a6a45e5ba811ef80dc42010a8a0006"
406
+ ],
407
+ "keywords_similarity_weight": 0.1,
408
+ "similarity_threshold": 0.02,
409
+ "top_n": 18
410
+ },
411
+ "label": "Retrieval",
412
+ "name": "DDL"
413
+ },
414
+ "dragging": false,
415
+ "height": 100,
416
+ "id": "Retrieval:StrongDrinksShare",
417
+ "position": {
418
+ "x": -43.93396035294677,
419
+ "y": -8.215558854318687
420
+ },
421
+ "positionAbsolute": {
422
+ "x": -43.93396035294677,
423
+ "y": -8.215558854318687
424
+ },
425
+ "selected": false,
426
+ "sourcePosition": "right",
427
+ "targetPosition": "left",
428
+ "type": "logicNode",
429
+ "width": 100
430
+ }
431
+ ]
432
+ },
433
+ "history": [],
434
+ "messages": [],
435
+ "path": [],
436
+ "reference": []
437
+ },
438
+ "avatar": ""
439
+ }