Kevin Hu commited on
Commit
544e97f
·
1 Parent(s): 8d43c11

Refine DB assistant template. (#4383)

Browse files

### What problem does this PR solve?

#4326

### Type of change

- [x] Bug Fix (non-breaking change which fixes an issue)

Files changed (1) hide show
  1. agent/templates/DB Assistant.json +801 -848
agent/templates/DB Assistant.json CHANGED
@@ -4,422 +4,74 @@
4
  "description": "An advanced agent that converts user queries into SQL statements, executes the queries, and assesses and returns the results. You must prepare three knowledge bases: 1: DDL for your database; 2: Examples of user queries converted to SQL statements; 3: A comprehensive description of your database, including but not limited to tables and records. You are also required to configure the corresponding database.",
5
  "canvas_type": "chatbot",
6
  "dsl": {
7
- "answer": [],
8
- "components": {
9
- "begin": {
10
- "obj": {
11
- "component_name": "Begin",
12
- "params": {}
13
- },
14
- "downstream": [
15
- "Answer:SocialAdsWonder"
16
- ],
17
- "upstream": []
18
- },
19
- "Answer:SocialAdsWonder": {
20
- "obj": {
21
- "component_name": "Answer",
22
- "params": {}
23
- },
24
- "downstream": [
25
- "Retrieval:SillyPartsCheer",
26
- "Retrieval:BrownStreetsRhyme",
27
- "Retrieval:OddSingersRefuse"
28
- ],
29
- "upstream": [
30
- "begin",
31
- "Switch:HotPartsTap"
32
- ]
33
- },
34
- "ExeSQL:CoolFactsChew": {
35
- "obj": {
36
- "component_name": "ExeSQL",
37
- "params": {
38
- "database": "Your DB name",
39
- "db_type": "mysql",
40
- "host": "Your IP Port",
41
- "loop": 3,
42
- "password": "Your Password",
43
- "port": 3306,
44
- "top_n": 9,
45
- "username": "Your username"
46
- }
47
- },
48
- "downstream": [
49
- "Switch:HotPartsTap"
50
- ],
51
- "upstream": [
52
- "Generate:SmoothWombatsRemain",
53
- "Generate:CuteSidesBuy"
54
- ]
55
- },
56
- "Switch:HotPartsTap": {
57
- "obj": {
58
- "component_name": "Switch",
59
- "params": {
60
- "conditions": [
61
- {
62
- "items": [
63
- {
64
- "cpn_id": "ExeSQL:CoolFactsChew",
65
- "operator": "contains",
66
- "value": "Error"
67
- },
68
- {
69
- "cpn_id": "ExeSQL:CoolFactsChew",
70
- "operator": "contains",
71
- "value": "**Error**"
72
- }
73
- ],
74
- "logical_operator": "or",
75
- "to": "Generate:SmoothWombatsRemain"
76
- }
77
- ],
78
- "end_cpn_id": "Answer:SocialAdsWonder"
79
- }
80
- },
81
- "downstream": [
82
- "Answer:SocialAdsWonder",
83
- "Generate:SmoothWombatsRemain"
84
- ],
85
- "upstream": [
86
- "ExeSQL:CoolFactsChew"
87
- ]
88
- },
89
- "Generate:SmoothWombatsRemain": {
90
- "obj": {
91
- "component_name": "Generate",
92
- "params": {
93
- "cite": true,
94
- "frequency_penalty": 0.7,
95
- "llm_id": "deepseek-chat@DeepSeek",
96
- "max_tokens": 256,
97
- "message_history_window_size": 12,
98
- "parameters": [
99
- {
100
- "component_id": "ExeSQL:CoolFactsChew",
101
- "id": "9c452513-6ab9-4ffb-8676-d7475363bb70",
102
- "key": "exesql_input"
103
- }
104
- ],
105
- "presence_penalty": 0.4,
106
- "prompt": "## You are the Repair SQL Statement Helper, please modify the original SQL statement based on the SQL query error report.\n\n## The contents of the SQL query error report and the original SQL statement are as follows:\n{exesql_input}\n\n## Answer only the modified SQL statement. Please do not give any explanation, just answer the code.",
107
- "temperature": 0.1,
108
- "top_p": 0.3
109
- }
110
- },
111
- "downstream": [
112
- "ExeSQL:CoolFactsChew"
113
- ],
114
- "upstream": [
115
- "Switch:HotPartsTap"
116
- ]
117
- },
118
- "Generate:CuteSidesBuy": {
119
- "obj": {
120
- "component_name": "Generate",
121
- "params": {
122
- "cite": true,
123
- "frequency_penalty": 0.7,
124
- "llm_id": "deepseek-chat@DeepSeek",
125
- "max_tokens": 256,
126
- "message_history_window_size": 12,
127
- "parameters": [
128
- {
129
- "component_id": "Retrieval:SillyPartsCheer",
130
- "id": "2a77e574-a0a6-4a1a-af39-cb192f1d21f5",
131
- "key": "ddl_input"
132
- },
133
- {
134
- "component_id": "Retrieval:OddSingersRefuse",
135
- "id": "83941a85-0b59-408e-97e5-504964b0e090",
136
- "key": "db_input"
137
- },
138
- {
139
- "component_id": "Retrieval:BrownStreetsRhyme",
140
- "id": "c63d0ae6-7ee2-44a2-8a95-69d03c90cb44",
141
- "key": "sql_input"
142
- }
143
- ],
144
- "presence_penalty": 0.4,
145
- "prompt": "\n##The user provides a question and you provide SQL. You will only respond with SQL code and not with any explanations.\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}.\n\n##Respond with only SQL code. Do not answer with any explanations -- just the code.",
146
- "temperature": 0.1,
147
- "top_p": 0.3
148
- }
149
- },
150
- "downstream": [
151
- "ExeSQL:CoolFactsChew"
152
- ],
153
- "upstream": [
154
- "Retrieval:SillyPartsCheer",
155
- "Retrieval:BrownStreetsRhyme",
156
- "Retrieval:OddSingersRefuse"
157
- ]
158
- },
159
- "Retrieval:SillyPartsCheer": {
160
- "obj": {
161
- "component_name": "Retrieval",
162
- "params": {
163
- "empty_response": "Nothing found in DDL!",
164
- "kb_ids": [],
165
- "keywords_similarity_weight": 0.1,
166
- "similarity_threshold": 0.02,
167
- "top_n": 18
168
- }
169
- },
170
- "downstream": [
171
- "Generate:CuteSidesBuy"
172
- ],
173
- "upstream": [
174
- "Answer:SocialAdsWonder"
175
- ]
176
- },
177
- "Retrieval:BrownStreetsRhyme": {
178
- "obj": {
179
- "component_name": "Retrieval",
180
- "params": {
181
- "empty_response": "Nothing found in Q->SQL!",
182
- "kb_ids": [],
183
- "keywords_similarity_weight": 0.3,
184
- "similarity_threshold": 0.2,
185
- "top_n": 8
186
- }
187
- },
188
- "downstream": [
189
- "Generate:CuteSidesBuy"
190
- ],
191
- "upstream": [
192
- "Answer:SocialAdsWonder"
193
- ]
194
- },
195
- "Retrieval:OddSingersRefuse": {
196
- "obj": {
197
- "component_name": "Retrieval",
198
- "params": {
199
- "empty_response": "Nothing found in DB-Description!",
200
- "kb_ids": [],
201
- "keywords_similarity_weight": 0.3,
202
- "similarity_threshold": 0.2,
203
- "top_n": 8
204
- }
205
- },
206
- "downstream": [
207
- "Generate:CuteSidesBuy"
208
- ],
209
- "upstream": [
210
- "Answer:SocialAdsWonder"
211
- ]
212
- }
213
- },
214
- "graph": {
215
- "nodes": [
216
- {
217
- "data": {
218
- "label": "Begin",
219
- "name": "begin"
220
- },
221
- "dragging": false,
222
- "height": 44,
223
- "id": "begin",
224
- "position": {
225
- "x": -707.997699967585,
226
- "y": 271.71609546793474
227
- },
228
- "positionAbsolute": {
229
- "x": -707.997699967585,
230
- "y": 271.71609546793474
231
- },
232
- "selected": false,
233
- "sourcePosition": "left",
234
- "targetPosition": "right",
235
- "type": "beginNode",
236
- "width": 100
237
- },
238
- {
239
- "data": {
240
- "form": {},
241
- "label": "Answer",
242
- "name": "Interface"
243
- },
244
- "dragging": false,
245
- "height": 44,
246
- "id": "Answer:SocialAdsWonder",
247
- "position": {
248
- "x": -58.36886074370702,
249
- "y": 272.1213623212045
250
- },
251
- "positionAbsolute": {
252
- "x": -58.36886074370702,
253
- "y": 272.1213623212045
254
- },
255
- "selected": false,
256
- "sourcePosition": "right",
257
- "targetPosition": "left",
258
- "type": "logicNode",
259
- "width": 200
260
- },
261
- {
262
- "data": {
263
- "form": {
264
- "database": "Your DB name",
265
  "db_type": "mysql",
266
- "host": "Your IP Port",
267
- "loop": 3,
268
- "password": "Your Password",
269
- "port": 3306,
270
- "top_n": 9,
271
- "username": "Your username"
272
- },
273
- "label": "ExeSQL",
274
- "name": "Execute SQL"
275
- },
276
- "dragging": false,
277
- "height": 44,
278
- "id": "ExeSQL:CoolFactsChew",
279
- "position": {
280
- "x": -328.98563704574315,
281
- "y": -177.64593432501485
282
- },
283
- "positionAbsolute": {
284
- "x": -328.98563704574315,
285
- "y": -177.64593432501485
286
- },
287
- "selected": false,
288
- "sourcePosition": "right",
289
- "targetPosition": "left",
290
- "type": "ragNode",
291
- "width": 200
292
- },
293
- {
294
- "data": {
295
- "form": {
296
- "conditions": [
297
- {
298
- "items": [
299
- {
300
- "cpn_id": "ExeSQL:CoolFactsChew",
301
- "operator": "contains",
302
- "value": "Error"
303
- },
304
- {
305
- "cpn_id": "ExeSQL:CoolFactsChew",
306
- "operator": "contains",
307
- "value": "**Error**"
308
- }
309
- ],
310
- "logical_operator": "or",
311
- "to": "Generate:SmoothWombatsRemain"
312
- }
313
- ],
314
- "end_cpn_id": "Answer:SocialAdsWonder"
315
- },
316
- "label": "Switch",
317
- "name": "Analyze SQL Result"
318
- },
319
- "dragging": false,
320
- "height": 191,
321
- "id": "Switch:HotPartsTap",
322
- "position": {
323
- "x": -333.34292578536326,
324
- "y": -51.66578195568452
325
- },
326
- "positionAbsolute": {
327
- "x": -333.34292578536326,
328
- "y": -51.66578195568452
329
- },
330
- "selected": false,
331
- "sourcePosition": "right",
332
- "targetPosition": "left",
333
- "type": "switchNode",
334
- "width": 200
335
- },
336
- {
337
- "data": {
338
- "form": {
339
- "text": "The large model modifies the original SQL statement based on the error message and returns the modified SQL statement."
340
- },
341
- "label": "Note",
342
- "name": "N: Fix SQL Statement"
343
- },
344
- "dragging": false,
345
- "height": 172,
346
- "id": "Note:SevenDancersMarry",
347
- "position": {
348
- "x": -52.470761864810754,
349
- "y": 81.77236559091028
350
- },
351
- "positionAbsolute": {
352
- "x": -52.470761864810754,
353
- "y": 81.77236559091028
354
- },
355
- "resizing": false,
356
- "selected": false,
357
- "sourcePosition": "right",
358
- "style": {
359
- "height": 172,
360
- "width": 228
361
- },
362
- "targetPosition": "left",
363
- "type": "noteNode",
364
- "width": 228
365
- },
366
- {
367
- "data": {
368
- "form": {
369
- "cite": true,
370
  "frequencyPenaltyEnabled": true,
371
  "frequency_penalty": 0.7,
 
372
  "llm_id": "deepseek-chat@DeepSeek",
 
373
  "maxTokensEnabled": true,
374
- "max_tokens": 256,
375
- "message_history_window_size": 12,
376
- "parameter": "Precise",
377
- "parameters": [
378
- {
379
- "component_id": "ExeSQL:CoolFactsChew",
380
- "id": "9c452513-6ab9-4ffb-8676-d7475363bb70",
381
- "key": "exesql_input"
382
- }
383
- ],
384
  "presencePenaltyEnabled": true,
385
  "presence_penalty": 0.4,
386
- "prompt": "## You are the Repair SQL Statement Helper, please modify the original SQL statement based on the SQL query error report.\n\n## The contents of the SQL query error report and the original SQL statement are as follows:\n{exesql_input}\n\n## Answer only the modified SQL statement. Please do not give any explanation, just answer the code.",
387
  "temperature": 0.1,
388
  "temperatureEnabled": true,
389
  "topPEnabled": true,
390
- "top_p": 0.3
391
- },
392
- "label": "Generate",
393
- "name": "Fix SQL Statement LLM"
394
- },
395
- "dragging": false,
396
- "height": 128,
397
- "id": "Generate:SmoothWombatsRemain",
398
- "position": {
399
- "x": -63.964315620743946,
400
- "y": -56.53893429100532
401
- },
402
- "positionAbsolute": {
403
- "x": -63.964315620743946,
404
- "y": -56.53893429100532
405
- },
406
- "selected": false,
407
- "sourcePosition": "right",
408
- "targetPosition": "left",
409
- "type": "generateNode",
410
- "width": 200
411
- },
412
- {
413
- "data": {
414
- "form": {
415
- "cite": true,
416
- "frequencyPenaltyEnabled": true,
417
  "frequency_penalty": 0.7,
418
  "llm_id": "deepseek-chat@DeepSeek",
419
- "maxTokensEnabled": true,
420
- "max_tokens": 256,
421
- "message_history_window_size": 12,
422
- "parameter": "Precise",
423
  "parameters": [
424
  {
425
  "component_id": "Retrieval:SillyPartsCheer",
@@ -437,495 +89,796 @@
437
  "key": "sql_input"
438
  }
439
  ],
440
- "presencePenaltyEnabled": true,
441
  "presence_penalty": 0.4,
442
  "prompt": "\n##The user provides a question and you provide SQL. You will only respond with SQL code and not with any explanations.\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}.\n\n##Respond with only SQL code. Do not answer with any explanations -- just the code.",
443
  "temperature": 0.1,
444
- "temperatureEnabled": true,
445
- "topPEnabled": true,
446
  "top_p": 0.3
447
- },
448
- "label": "Generate",
449
- "name": "Generate SQL Statement LLM"
450
- },
451
- "dragging": false,
452
- "height": 212,
453
- "id": "Generate:CuteSidesBuy",
454
- "position": {
455
- "x": 191.98081287844155,
456
- "y": -255.36496490928363
457
- },
458
- "positionAbsolute": {
459
- "x": 191.98081287844155,
460
- "y": -255.36496490928363
461
- },
462
- "selected": false,
463
- "sourcePosition": "right",
464
- "targetPosition": "left",
465
- "type": "generateNode",
466
- "width": 200
467
- },
468
- {
469
- "data": {
470
- "form": {
471
- "empty_response": "Nothing found in DDL!",
472
- "kb_ids": [],
473
- "keywords_similarity_weight": 0.1,
474
- "similarity_threshold": 0.02,
475
- "top_n": 18
476
- },
477
- "label": "Retrieval",
478
- "name": "DDL"
479
- },
480
- "dragging": false,
481
- "height": 44,
482
- "id": "Retrieval:SillyPartsCheer",
483
- "position": {
484
- "x": 199.0075429691716,
485
- "y": -0.9595420072386389
486
- },
487
- "positionAbsolute": {
488
- "x": 199.0075429691716,
489
- "y": -0.9595420072386389
490
- },
491
- "selected": false,
492
- "sourcePosition": "right",
493
- "targetPosition": "left",
494
- "type": "retrievalNode",
495
- "width": 200
496
- },
497
- {
498
- "data": {
499
- "form": {
500
  "empty_response": "Nothing found in Q->SQL!",
501
  "kb_ids": [],
502
  "keywords_similarity_weight": 0.3,
 
 
 
 
 
 
503
  "similarity_threshold": 0.2,
504
  "top_n": 8
505
- },
506
- "label": "Retrieval",
507
- "name": "Q->SQL"
508
- },
509
- "dragging": false,
510
- "height": 44,
511
- "id": "Retrieval:BrownStreetsRhyme",
512
- "position": {
513
- "x": 219.1804193484379,
514
- "y": 113.85464274901977
515
- },
516
- "positionAbsolute": {
517
- "x": 219.1804193484379,
518
- "y": 113.85464274901977
519
- },
520
- "selected": false,
521
- "sourcePosition": "right",
522
- "targetPosition": "left",
523
- "type": "retrievalNode",
524
- "width": 200
525
- },
526
- {
527
- "data": {
528
- "form": {
529
  "empty_response": "Nothing found in DB-Description!",
530
  "kb_ids": [],
531
  "keywords_similarity_weight": 0.3,
 
 
 
 
 
 
532
  "similarity_threshold": 0.2,
533
  "top_n": 8
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
534
  },
535
- "label": "Retrieval",
536
- "name": "DB Description"
537
  },
538
- "dragging": false,
539
- "height": 44,
540
- "id": "Retrieval:OddSingersRefuse",
541
- "position": {
542
- "x": 267.7575479510707,
543
- "y": 249.15603226400776
544
- },
545
- "positionAbsolute": {
546
- "x": 267.7575479510707,
547
- "y": 249.15603226400776
548
- },
549
- "selected": false,
550
- "sourcePosition": "right",
551
- "targetPosition": "left",
552
- "type": "retrievalNode",
553
- "width": 200
554
- },
555
- {
556
- "data": {
557
- "form": {
558
- "text": "Based on the result of the SQL execution, returns the error message to the large model if any errors occur; otherwise, returns the result to the user."
559
  },
560
- "label": "Note",
561
- "name": "N: Analyze SQL"
562
- },
563
- "dragging": false,
564
- "height": 176,
565
- "id": "Note:HeavyIconsFollow",
566
- "position": {
567
- "x": -626.6563777191027,
568
- "y": -48.82220889683933
569
- },
570
- "positionAbsolute": {
571
- "x": -626.6563777191027,
572
- "y": -48.82220889683933
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
573
  },
574
- "resizing": false,
575
- "selected": false,
576
- "sourcePosition": "right",
577
- "style": {
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
578
  "height": 176,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
579
  "width": 266
580
  },
581
- "targetPosition": "left",
582
- "type": "noteNode",
583
- "width": 266,
584
- "dragHandle": ".note-drag-handle"
585
- },
586
- {
587
- "data": {
588
- "form": {
589
- "text": "Receives the user's database-related questions and displays the large model's response."
590
  },
591
- "label": "Note",
592
- "name": "N: Interface"
593
- },
594
- "dragging": false,
595
- "height": 162,
596
- "id": "Note:PinkTaxesClean",
597
- "position": {
598
- "x": -52.004609812312424,
599
- "y": 336.95180237635077
600
- },
601
- "positionAbsolute": {
602
- "x": -52.004609812312424,
603
- "y": 336.95180237635077
604
- },
605
- "resizing": false,
606
- "selected": false,
607
- "sourcePosition": "right",
608
- "style": {
609
  "height": 162,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
610
  "width": 210
611
  },
612
- "targetPosition": "left",
613
- "type": "noteNode",
614
- "width": 210,
615
- "dragHandle": ".note-drag-handle"
616
- },
617
- {
618
- "data": {
619
- "form": {
620
- "text": "Searches for description about meanings of tables and fields."
621
  },
622
- "label": "Note",
623
- "name": "N:DB Description"
624
- },
625
- "dragging": false,
626
- "height": 128,
627
- "id": "Note:IcyTreesPeel",
628
- "position": {
629
- "x": 283.6653421557703,
630
- "y": 336.29235267887395
631
- },
632
- "positionAbsolute": {
633
- "x": 283.6653421557703,
634
- "y": 336.29235267887395
635
- },
636
- "resizing": false,
637
- "selected": false,
638
- "sourcePosition": "right",
639
- "style": {
640
  "height": 128,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
641
  "width": 251
642
  },
643
- "targetPosition": "left",
644
- "type": "noteNode",
645
- "width": 251,
646
- "dragHandle": ".note-drag-handle"
647
- },
648
- {
649
- "data": {
650
- "form": {
651
- "text": "Searches for samples about question to SQL.\nPlease check this dataset: https://huggingface.co/datasets/InfiniFlow/text2sql"
652
  },
653
- "label": "Note",
654
- "name": "N: Q->SQL"
655
- },
656
- "dragging": false,
657
- "height": 131,
658
- "id": "Note:HugeGroupsScream",
659
- "position": {
660
- "x": 606.1206536213404,
661
- "y": 113.09441734894426
662
- },
663
- "positionAbsolute": {
664
- "x": 606.1206536213404,
665
- "y": 113.09441734894426
666
- },
667
- "resizing": false,
668
- "selected": false,
669
- "sourcePosition": "right",
670
- "style": {
671
  "height": 131,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
672
  "width": 387
673
  },
674
- "targetPosition": "left",
675
- "type": "noteNode",
676
- "width": 387,
677
- "dragHandle": ".note-drag-handle"
678
- },
679
- {
680
- "data": {
681
- "form": {
682
- "text": "DDL(Data Definition Language).\n\nSearches for relevant database creation statements.\n\nIt should bind with a KB to which DDL is dumped in.\nYou could use 'General' as parsing method and ';' as delimiter."
683
  },
684
- "label": "Note",
685
- "name": "N: DDL"
686
- },
687
- "dragging": false,
688
- "height": 266,
689
- "id": "Note:GreenCrewsArrive",
690
- "position": {
691
- "x": 545.3423934788841,
692
- "y": -166.58872868890683
693
- },
694
- "positionAbsolute": {
695
- "x": 545.3423934788841,
696
- "y": -166.58872868890683
697
- },
698
- "resizing": false,
699
- "selected": false,
700
- "sourcePosition": "right",
701
- "style": {
702
  "height": 266,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
703
  "width": 266
704
  },
705
- "targetPosition": "left",
706
- "type": "noteNode",
707
- "width": 266,
708
- "dragHandle": ".note-drag-handle"
709
- },
710
- {
711
- "data": {
712
- "form": {
713
- "text": "The large model learns which tables may be available based on the responses from three knowledge bases and converts the user's input into SQL statements."
714
  },
715
- "label": "Note",
716
- "name": "N: Generate SQL"
717
- },
718
- "dragging": false,
719
- "height": 175,
720
- "id": "Note:EightTurtlesLike",
721
- "position": {
722
- "x": 222.2150747084395,
723
- "y": -445.32694170868734
724
- },
725
- "positionAbsolute": {
726
- "x": 222.2150747084395,
727
- "y": -445.32694170868734
728
- },
729
- "resizing": false,
730
- "selected": false,
731
- "sourcePosition": "right",
732
- "style": {
733
  "height": 175,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
734
  "width": 265
735
  },
736
- "targetPosition": "left",
737
- "type": "noteNode",
738
- "width": 265,
739
- "dragHandle": ".note-drag-handle"
740
- },
741
- {
742
- "data": {
743
- "form": {
744
- "text": "Executes the SQL statement in the database and returns the result.\n\nAfter configuring an accessible database, press 'Test' to ensure the accessibility."
745
  },
746
- "label": "Note",
747
- "name": "N: Execute SQL"
748
- },
749
- "dragging": false,
750
- "height": 178,
751
- "id": "Note:FreshKidsTalk",
752
- "position": {
753
- "x": -251.5866574377311,
754
- "y": -372.2192837064241
755
- },
756
- "positionAbsolute": {
757
- "x": -251.5866574377311,
758
- "y": -372.2192837064241
759
- },
760
- "resizing": false,
761
- "selected": false,
762
- "sourcePosition": "right",
763
- "style": {
764
  "height": 178,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
765
  "width": 346
766
  },
767
- "targetPosition": "left",
768
- "type": "noteNode",
769
- "width": 346,
770
- "dragHandle": ".note-drag-handle"
771
- }
772
- ],
773
- "edges": [
774
- {
775
- "id": "reactflow__edge-begin-Answer:SocialAdsWonderc",
776
- "markerEnd": "logo",
777
- "source": "begin",
778
- "sourceHandle": null,
779
- "style": {
780
- "stroke": "rgb(202 197 245)",
781
- "strokeWidth": 2
782
- },
783
- "target": "Answer:SocialAdsWonder",
784
- "targetHandle": "c",
785
- "type": "buttonEdge"
786
- },
787
- {
788
- "id": "reactflow__edge-ExeSQL:CoolFactsChewc-Switch:HotPartsTapa",
789
- "markerEnd": "logo",
790
- "source": "ExeSQL:CoolFactsChew",
791
- "sourceHandle": "c",
792
- "style": {
793
- "stroke": "rgb(202 197 245)",
794
- "strokeWidth": 2
795
- },
796
- "target": "Switch:HotPartsTap",
797
- "targetHandle": "a",
798
- "type": "buttonEdge"
799
- },
800
- {
801
- "id": "24dc76bf-2030-465e-9dd8-f4a784fd2b49",
802
- "source": "Switch:HotPartsTap",
803
- "sourceHandle": "end_cpn_id",
804
- "target": "Answer:SocialAdsWonder"
805
- },
806
- {
807
- "id": "reactflow__edge-Switch:HotPartsTapCase 1-Generate:SmoothWombatsRemainc",
808
- "markerEnd": "logo",
809
- "source": "Switch:HotPartsTap",
810
- "sourceHandle": "Case 1",
811
- "style": {
812
- "stroke": "rgb(202 197 245)",
813
- "strokeWidth": 2
814
- },
815
- "target": "Generate:SmoothWombatsRemain",
816
- "targetHandle": "c",
817
- "type": "buttonEdge"
818
- },
819
- {
820
- "id": "reactflow__edge-Generate:SmoothWombatsRemainb-ExeSQL:CoolFactsChewb",
821
- "markerEnd": "logo",
822
- "source": "Generate:SmoothWombatsRemain",
823
- "sourceHandle": "b",
824
- "style": {
825
- "stroke": "rgb(202 197 245)",
826
- "strokeWidth": 2
827
- },
828
- "target": "ExeSQL:CoolFactsChew",
829
- "targetHandle": "b",
830
- "type": "buttonEdge"
831
- },
832
- {
833
- "id": "reactflow__edge-Answer:SocialAdsWonderb-Retrieval:SillyPartsCheerc",
834
- "markerEnd": "logo",
835
- "source": "Answer:SocialAdsWonder",
836
- "sourceHandle": "b",
837
- "style": {
838
- "stroke": "rgb(202 197 245)",
839
- "strokeWidth": 2
840
- },
841
- "target": "Retrieval:SillyPartsCheer",
842
- "targetHandle": "c",
843
- "type": "buttonEdge"
844
- },
845
- {
846
- "id": "reactflow__edge-Answer:SocialAdsWonderb-Retrieval:BrownStreetsRhymec",
847
- "markerEnd": "logo",
848
- "source": "Answer:SocialAdsWonder",
849
- "sourceHandle": "b",
850
- "style": {
851
- "stroke": "rgb(202 197 245)",
852
- "strokeWidth": 2
853
- },
854
- "target": "Retrieval:BrownStreetsRhyme",
855
- "targetHandle": "c",
856
- "type": "buttonEdge"
857
- },
858
- {
859
- "id": "reactflow__edge-Answer:SocialAdsWonderb-Retrieval:OddSingersRefusec",
860
- "markerEnd": "logo",
861
- "source": "Answer:SocialAdsWonder",
862
- "sourceHandle": "b",
863
- "style": {
864
- "stroke": "rgb(202 197 245)",
865
- "strokeWidth": 2
866
- },
867
- "target": "Retrieval:OddSingersRefuse",
868
- "targetHandle": "c",
869
- "type": "buttonEdge"
870
- },
871
- {
872
- "id": "reactflow__edge-Generate:CuteSidesBuyc-ExeSQL:CoolFactsChewb",
873
- "markerEnd": "logo",
874
- "source": "Generate:CuteSidesBuy",
875
- "sourceHandle": "c",
876
- "style": {
877
- "stroke": "rgb(202 197 245)",
878
- "strokeWidth": 2
879
- },
880
- "target": "ExeSQL:CoolFactsChew",
881
- "targetHandle": "b",
882
- "type": "buttonEdge"
883
- },
884
- {
885
- "id": "reactflow__edge-Retrieval:SillyPartsCheerb-Generate:CuteSidesBuyb",
886
- "markerEnd": "logo",
887
- "source": "Retrieval:SillyPartsCheer",
888
- "sourceHandle": "b",
889
- "style": {
890
- "stroke": "rgb(202 197 245)",
891
- "strokeWidth": 2
892
- },
893
- "target": "Generate:CuteSidesBuy",
894
- "targetHandle": "b",
895
- "type": "buttonEdge"
896
- },
897
- {
898
- "id": "reactflow__edge-Retrieval:BrownStreetsRhymeb-Generate:CuteSidesBuyb",
899
- "markerEnd": "logo",
900
- "source": "Retrieval:BrownStreetsRhyme",
901
- "sourceHandle": "b",
902
- "style": {
903
- "stroke": "rgb(202 197 245)",
904
- "strokeWidth": 2
905
- },
906
- "target": "Generate:CuteSidesBuy",
907
- "targetHandle": "b",
908
- "type": "buttonEdge"
909
- },
910
- {
911
- "id": "reactflow__edge-Retrieval:OddSingersRefuseb-Generate:CuteSidesBuyb",
912
- "markerEnd": "logo",
913
- "source": "Retrieval:OddSingersRefuse",
914
- "sourceHandle": "b",
915
- "style": {
916
- "stroke": "rgb(202 197 245)",
917
- "strokeWidth": 2
918
- },
919
- "target": "Generate:CuteSidesBuy",
920
- "targetHandle": "b",
921
- "type": "buttonEdge"
922
- }
923
- ]
924
  },
925
- "history": [],
926
- "messages": [],
927
- "path": [],
928
- "reference": []
929
- },
930
  "avatar": ""
931
  }
 
4
  "description": "An advanced agent that converts user queries into SQL statements, executes the queries, and assesses and returns the results. You must prepare three knowledge bases: 1: DDL for your database; 2: Examples of user queries converted to SQL statements; 3: A comprehensive description of your database, including but not limited to tables and records. You are also required to configure the corresponding database.",
5
  "canvas_type": "chatbot",
6
  "dsl": {
7
+ "answer": [],
8
+ "components": {
9
+ "Answer:SocialAdsWonder": {
10
+ "downstream": [
11
+ "Retrieval:SillyPartsCheer",
12
+ "Retrieval:BrownStreetsRhyme",
13
+ "Retrieval:OddSingersRefuse"
14
+ ],
15
+ "obj": {
16
+ "component_name": "Answer",
17
+ "inputs": [],
18
+ "output": {},
19
+ "params": {}
20
+ },
21
+ "upstream": [
22
+ "begin",
23
+ "ExeSQL:QuietRosesRun"
24
+ ]
25
+ },
26
+ "ExeSQL:QuietRosesRun": {
27
+ "downstream": [
28
+ "Answer:SocialAdsWonder"
29
+ ],
30
+ "obj": {
31
+ "component_name": "ExeSQL",
32
+ "inputs": [],
33
+ "output": {},
34
+ "params": {
35
+ "database": "",
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
36
  "db_type": "mysql",
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
37
  "frequencyPenaltyEnabled": true,
38
  "frequency_penalty": 0.7,
39
+ "host": "",
40
  "llm_id": "deepseek-chat@DeepSeek",
41
+ "loop": 3,
42
  "maxTokensEnabled": true,
43
+ "max_tokens": 512,
44
+ "password": "",
45
+ "port": 6630,
 
 
 
 
 
 
 
46
  "presencePenaltyEnabled": true,
47
  "presence_penalty": 0.4,
48
+ "query": [],
49
  "temperature": 0.1,
50
  "temperatureEnabled": true,
51
  "topPEnabled": true,
52
+ "top_n": 30,
53
+ "top_p": 0.3,
54
+ "username": "root"
55
+ }
56
+ },
57
+ "upstream": [
58
+ "Generate:CuteSidesBuy"
59
+ ]
60
+ },
61
+ "Generate:CuteSidesBuy": {
62
+ "downstream": [
63
+ "ExeSQL:QuietRosesRun"
64
+ ],
65
+ "obj": {
66
+ "component_name": "Generate",
67
+ "inputs": [],
68
+ "output": {},
69
+ "params": {
70
+ "cite": false,
 
 
 
 
 
 
 
 
71
  "frequency_penalty": 0.7,
72
  "llm_id": "deepseek-chat@DeepSeek",
73
+ "max_tokens": 512,
74
+ "message_history_window_size": 1,
 
 
75
  "parameters": [
76
  {
77
  "component_id": "Retrieval:SillyPartsCheer",
 
89
  "key": "sql_input"
90
  }
91
  ],
 
92
  "presence_penalty": 0.4,
93
  "prompt": "\n##The user provides a question and you provide SQL. You will only respond with SQL code and not with any explanations.\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}.\n\n##Respond with only SQL code. Do not answer with any explanations -- just the code.",
94
  "temperature": 0.1,
 
 
95
  "top_p": 0.3
96
+ }
97
+ },
98
+ "upstream": [
99
+ "Retrieval:SillyPartsCheer",
100
+ "Retrieval:BrownStreetsRhyme",
101
+ "Retrieval:OddSingersRefuse"
102
+ ]
103
+ },
104
+ "Retrieval:BrownStreetsRhyme": {
105
+ "downstream": [
106
+ "Generate:CuteSidesBuy"
107
+ ],
108
+ "obj": {
109
+ "component_name": "Retrieval",
110
+ "inputs": [],
111
+ "output": {},
112
+ "params": {
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
113
  "empty_response": "Nothing found in Q->SQL!",
114
  "kb_ids": [],
115
  "keywords_similarity_weight": 0.3,
116
+ "query": [
117
+ {
118
+ "component_id": "Answer:SocialAdsWonder",
119
+ "type": "reference"
120
+ }
121
+ ],
122
  "similarity_threshold": 0.2,
123
  "top_n": 8
124
+ }
125
+ },
126
+ "upstream": [
127
+ "Answer:SocialAdsWonder"
128
+ ]
129
+ },
130
+ "Retrieval:OddSingersRefuse": {
131
+ "downstream": [
132
+ "Generate:CuteSidesBuy"
133
+ ],
134
+ "obj": {
135
+ "component_name": "Retrieval",
136
+ "inputs": [],
137
+ "output": {},
138
+ "params": {
 
 
 
 
 
 
 
 
 
139
  "empty_response": "Nothing found in DB-Description!",
140
  "kb_ids": [],
141
  "keywords_similarity_weight": 0.3,
142
+ "query": [
143
+ {
144
+ "component_id": "Answer:SocialAdsWonder",
145
+ "type": "reference"
146
+ }
147
+ ],
148
  "similarity_threshold": 0.2,
149
  "top_n": 8
150
+ }
151
+ },
152
+ "upstream": [
153
+ "Answer:SocialAdsWonder"
154
+ ]
155
+ },
156
+ "Retrieval:SillyPartsCheer": {
157
+ "downstream": [
158
+ "Generate:CuteSidesBuy"
159
+ ],
160
+ "obj": {
161
+ "component_name": "Retrieval",
162
+ "inputs": [],
163
+ "output": {},
164
+ "params": {
165
+ "empty_response": "Nothing found in DDL!",
166
+ "kb_ids": [],
167
+ "keywords_similarity_weight": 0.1,
168
+ "query": [
169
+ {
170
+ "component_id": "Answer:SocialAdsWonder",
171
+ "type": "reference"
172
+ }
173
+ ],
174
+ "similarity_threshold": 0.02,
175
+ "top_n": 18
176
+ }
177
+ },
178
+ "upstream": [
179
+ "Answer:SocialAdsWonder"
180
+ ]
181
+ },
182
+ "begin": {
183
+ "downstream": [
184
+ "Answer:SocialAdsWonder"
185
+ ],
186
+ "obj": {
187
+ "component_name": "Begin",
188
+ "inputs": [],
189
+ "output": {
190
+ "content": {
191
+ "0": {
192
+ "content": "Hi! I'm your smart assistant. What can I do for you?"
193
+ }
194
+ }
195
  },
196
+ "params": {}
 
197
  },
198
+ "upstream": []
199
+ }
200
+ },
201
+ "embed_id": "BAAI/bge-large-zh-v1.5",
202
+ "graph": {
203
+ "edges": [
204
+ {
205
+ "id": "reactflow__edge-begin-Answer:SocialAdsWonderc",
206
+ "markerEnd": "logo",
207
+ "source": "begin",
208
+ "sourceHandle": null,
209
+ "style": {
210
+ "stroke": "rgb(202 197 245)",
211
+ "strokeWidth": 2
 
 
 
 
 
 
 
212
  },
213
+ "target": "Answer:SocialAdsWonder",
214
+ "targetHandle": "c",
215
+ "type": "buttonEdge"
216
+ },
217
+ {
218
+ "id": "reactflow__edge-Answer:SocialAdsWonderb-Retrieval:SillyPartsCheerc",
219
+ "markerEnd": "logo",
220
+ "source": "Answer:SocialAdsWonder",
221
+ "sourceHandle": "b",
222
+ "style": {
223
+ "stroke": "rgb(202 197 245)",
224
+ "strokeWidth": 2
225
+ },
226
+ "target": "Retrieval:SillyPartsCheer",
227
+ "targetHandle": "c",
228
+ "type": "buttonEdge"
229
+ },
230
+ {
231
+ "id": "reactflow__edge-Answer:SocialAdsWonderb-Retrieval:BrownStreetsRhymec",
232
+ "markerEnd": "logo",
233
+ "source": "Answer:SocialAdsWonder",
234
+ "sourceHandle": "b",
235
+ "style": {
236
+ "stroke": "rgb(202 197 245)",
237
+ "strokeWidth": 2
238
+ },
239
+ "target": "Retrieval:BrownStreetsRhyme",
240
+ "targetHandle": "c",
241
+ "type": "buttonEdge"
242
+ },
243
+ {
244
+ "id": "reactflow__edge-Answer:SocialAdsWonderb-Retrieval:OddSingersRefusec",
245
+ "markerEnd": "logo",
246
+ "source": "Answer:SocialAdsWonder",
247
+ "sourceHandle": "b",
248
+ "style": {
249
+ "stroke": "rgb(202 197 245)",
250
+ "strokeWidth": 2
251
+ },
252
+ "target": "Retrieval:OddSingersRefuse",
253
+ "targetHandle": "c",
254
+ "type": "buttonEdge"
255
+ },
256
+ {
257
+ "id": "reactflow__edge-Retrieval:SillyPartsCheerb-Generate:CuteSidesBuyb",
258
+ "markerEnd": "logo",
259
+ "source": "Retrieval:SillyPartsCheer",
260
+ "sourceHandle": "b",
261
+ "style": {
262
+ "stroke": "rgb(202 197 245)",
263
+ "strokeWidth": 2
264
+ },
265
+ "target": "Generate:CuteSidesBuy",
266
+ "targetHandle": "b",
267
+ "type": "buttonEdge"
268
+ },
269
+ {
270
+ "id": "reactflow__edge-Retrieval:BrownStreetsRhymeb-Generate:CuteSidesBuyb",
271
+ "markerEnd": "logo",
272
+ "source": "Retrieval:BrownStreetsRhyme",
273
+ "sourceHandle": "b",
274
+ "style": {
275
+ "stroke": "rgb(202 197 245)",
276
+ "strokeWidth": 2
277
+ },
278
+ "target": "Generate:CuteSidesBuy",
279
+ "targetHandle": "b",
280
+ "type": "buttonEdge"
281
+ },
282
+ {
283
+ "id": "reactflow__edge-Retrieval:OddSingersRefuseb-Generate:CuteSidesBuyb",
284
+ "markerEnd": "logo",
285
+ "source": "Retrieval:OddSingersRefuse",
286
+ "sourceHandle": "b",
287
+ "style": {
288
+ "stroke": "rgb(202 197 245)",
289
+ "strokeWidth": 2
290
+ },
291
+ "target": "Generate:CuteSidesBuy",
292
+ "targetHandle": "b",
293
+ "type": "buttonEdge"
294
+ },
295
+ {
296
+ "id": "xy-edge__Generate:CuteSidesBuyc-ExeSQL:QuietRosesRunb",
297
+ "markerEnd": "logo",
298
+ "source": "Generate:CuteSidesBuy",
299
+ "sourceHandle": "c",
300
+ "style": {
301
+ "stroke": "rgb(202 197 245)",
302
+ "strokeWidth": 2
303
+ },
304
+ "target": "ExeSQL:QuietRosesRun",
305
+ "targetHandle": "b",
306
+ "type": "buttonEdge",
307
+ "zIndex": 1001
308
+ },
309
+ {
310
+ "id": "xy-edge__ExeSQL:QuietRosesRunc-Answer:SocialAdsWonderc",
311
+ "markerEnd": "logo",
312
+ "source": "ExeSQL:QuietRosesRun",
313
+ "sourceHandle": "c",
314
+ "style": {
315
+ "stroke": "rgb(202 197 245)",
316
+ "strokeWidth": 2
317
+ },
318
+ "target": "Answer:SocialAdsWonder",
319
+ "targetHandle": "c",
320
+ "type": "buttonEdge",
321
+ "zIndex": 1001
322
+ }
323
+ ],
324
+ "nodes": [
325
+ {
326
+ "data": {
327
+ "label": "Begin",
328
+ "name": "begin"
329
+ },
330
+ "dragging": false,
331
+ "height": 44,
332
+ "id": "begin",
333
+ "measured": {
334
+ "height": 44,
335
+ "width": 200
336
+ },
337
+ "position": {
338
+ "x": -707.997699967585,
339
+ "y": 271.71609546793474
340
+ },
341
+ "positionAbsolute": {
342
+ "x": -707.997699967585,
343
+ "y": 271.71609546793474
344
+ },
345
+ "selected": false,
346
+ "sourcePosition": "left",
347
+ "targetPosition": "right",
348
+ "type": "beginNode",
349
+ "width": 200
350
+ },
351
+ {
352
+ "data": {
353
+ "form": {},
354
+ "label": "Answer",
355
+ "name": "Interface"
356
+ },
357
+ "dragging": false,
358
+ "height": 44,
359
+ "id": "Answer:SocialAdsWonder",
360
+ "measured": {
361
+ "height": 44,
362
+ "width": 200
363
+ },
364
+ "position": {
365
+ "x": -58.36886074370702,
366
+ "y": 272.1213623212045
367
+ },
368
+ "positionAbsolute": {
369
+ "x": -58.36886074370702,
370
+ "y": 272.1213623212045
371
+ },
372
+ "selected": false,
373
+ "sourcePosition": "right",
374
+ "targetPosition": "left",
375
+ "type": "logicNode",
376
+ "width": 200
377
+ },
378
+ {
379
+ "data": {
380
+ "form": {
381
+ "text": "The large model modifies the original SQL statement based on the error message and returns the modified SQL statement."
382
+ },
383
+ "label": "Note",
384
+ "name": "N: Fix SQL Statement"
385
+ },
386
+ "dragging": false,
387
+ "height": 172,
388
+ "id": "Note:SevenDancersMarry",
389
+ "measured": {
390
+ "height": 172,
391
+ "width": 228
392
+ },
393
+ "position": {
394
+ "x": -62.91736862436424,
395
+ "y": 93.08952291375991
396
+ },
397
+ "positionAbsolute": {
398
+ "x": -62.91736862436424,
399
+ "y": 93.08952291375991
400
+ },
401
+ "resizing": false,
402
+ "selected": false,
403
+ "sourcePosition": "right",
404
+ "style": {
405
+ "height": 172,
406
+ "width": 228
407
+ },
408
+ "targetPosition": "left",
409
+ "type": "noteNode",
410
+ "width": 228
411
  },
412
+ {
413
+ "data": {
414
+ "form": {
415
+ "cite": false,
416
+ "frequencyPenaltyEnabled": true,
417
+ "frequency_penalty": 0.7,
418
+ "llm_id": "deepseek-chat@DeepSeek",
419
+ "maxTokensEnabled": true,
420
+ "max_tokens": 512,
421
+ "message_history_window_size": 1,
422
+ "parameter": "Precise",
423
+ "parameters": [
424
+ {
425
+ "component_id": "Retrieval:SillyPartsCheer",
426
+ "id": "2a77e574-a0a6-4a1a-af39-cb192f1d21f5",
427
+ "key": "ddl_input"
428
+ },
429
+ {
430
+ "component_id": "Retrieval:OddSingersRefuse",
431
+ "id": "83941a85-0b59-408e-97e5-504964b0e090",
432
+ "key": "db_input"
433
+ },
434
+ {
435
+ "component_id": "Retrieval:BrownStreetsRhyme",
436
+ "id": "c63d0ae6-7ee2-44a2-8a95-69d03c90cb44",
437
+ "key": "sql_input"
438
+ }
439
+ ],
440
+ "presencePenaltyEnabled": true,
441
+ "presence_penalty": 0.4,
442
+ "prompt": "\n##The user provides a question and you provide SQL. You will only respond with SQL code and not with any explanations.\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}.\n\n##Respond with only SQL code. Do not answer with any explanations -- just the code.",
443
+ "temperature": 0.1,
444
+ "temperatureEnabled": true,
445
+ "topPEnabled": true,
446
+ "top_p": 0.3
447
+ },
448
+ "label": "Generate",
449
+ "name": "Generate SQL Statement LLM"
450
+ },
451
+ "dragging": false,
452
+ "height": 232,
453
+ "id": "Generate:CuteSidesBuy",
454
+ "measured": {
455
+ "height": 232,
456
+ "width": 200
457
+ },
458
+ "position": {
459
+ "x": 191.98081287844155,
460
+ "y": -255.36496490928363
461
+ },
462
+ "positionAbsolute": {
463
+ "x": 191.98081287844155,
464
+ "y": -255.36496490928363
465
+ },
466
+ "selected": false,
467
+ "sourcePosition": "right",
468
+ "targetPosition": "left",
469
+ "type": "generateNode",
470
+ "width": 200
471
+ },
472
+ {
473
+ "data": {
474
+ "form": {
475
+ "empty_response": "Nothing found in DDL!",
476
+ "kb_ids": [],
477
+ "keywords_similarity_weight": 0.1,
478
+ "query": [
479
+ {
480
+ "component_id": "Answer:SocialAdsWonder",
481
+ "type": "reference"
482
+ }
483
+ ],
484
+ "similarity_threshold": 0.02,
485
+ "top_n": 18
486
+ },
487
+ "label": "Retrieval",
488
+ "name": "DDL"
489
+ },
490
+ "dragging": false,
491
+ "height": 106,
492
+ "id": "Retrieval:SillyPartsCheer",
493
+ "measured": {
494
+ "height": 106,
495
+ "width": 200
496
+ },
497
+ "position": {
498
+ "x": 198.3020069445181,
499
+ "y": -0.9595420072386389
500
+ },
501
+ "positionAbsolute": {
502
+ "x": 198.3020069445181,
503
+ "y": -0.9595420072386389
504
+ },
505
+ "selected": false,
506
+ "sourcePosition": "right",
507
+ "targetPosition": "left",
508
+ "type": "retrievalNode",
509
+ "width": 200
510
+ },
511
+ {
512
+ "data": {
513
+ "form": {
514
+ "empty_response": "Nothing found in Q->SQL!",
515
+ "kb_ids": [],
516
+ "keywords_similarity_weight": 0.3,
517
+ "query": [
518
+ {
519
+ "component_id": "Answer:SocialAdsWonder",
520
+ "type": "reference"
521
+ }
522
+ ],
523
+ "similarity_threshold": 0.2,
524
+ "top_n": 8
525
+ },
526
+ "label": "Retrieval",
527
+ "name": "Q->SQL"
528
+ },
529
+ "dragging": false,
530
+ "height": 106,
531
+ "id": "Retrieval:BrownStreetsRhyme",
532
+ "measured": {
533
+ "height": 106,
534
+ "width": 200
535
+ },
536
+ "position": {
537
+ "x": 231.17453176754782,
538
+ "y": 123.02661106951555
539
+ },
540
+ "positionAbsolute": {
541
+ "x": 231.17453176754782,
542
+ "y": 123.02661106951555
543
+ },
544
+ "selected": false,
545
+ "sourcePosition": "right",
546
+ "targetPosition": "left",
547
+ "type": "retrievalNode",
548
+ "width": 200
549
+ },
550
+ {
551
+ "data": {
552
+ "form": {
553
+ "empty_response": "Nothing found in DB-Description!",
554
+ "kb_ids": [],
555
+ "keywords_similarity_weight": 0.3,
556
+ "query": [
557
+ {
558
+ "component_id": "Answer:SocialAdsWonder",
559
+ "type": "reference"
560
+ }
561
+ ],
562
+ "similarity_threshold": 0.2,
563
+ "top_n": 8
564
+ },
565
+ "label": "Retrieval",
566
+ "name": "DB Description"
567
+ },
568
+ "dragging": false,
569
+ "height": 106,
570
+ "id": "Retrieval:OddSingersRefuse",
571
+ "measured": {
572
+ "height": 106,
573
+ "width": 200
574
+ },
575
+ "position": {
576
+ "x": 267.7575479510707,
577
+ "y": 249.15603226400776
578
+ },
579
+ "positionAbsolute": {
580
+ "x": 267.7575479510707,
581
+ "y": 249.15603226400776
582
+ },
583
+ "selected": false,
584
+ "sourcePosition": "right",
585
+ "targetPosition": "left",
586
+ "type": "retrievalNode",
587
+ "width": 200
588
+ },
589
+ {
590
+ "data": {
591
+ "form": {
592
+ "text": "Based on the result of the SQL execution, returns the error message to the large model if any errors occur; otherwise, returns the result to the user."
593
+ },
594
+ "label": "Note",
595
+ "name": "N: Analyze SQL"
596
+ },
597
+ "dragHandle": ".note-drag-handle",
598
+ "dragging": false,
599
  "height": 176,
600
+ "id": "Note:HeavyIconsFollow",
601
+ "measured": {
602
+ "height": 176,
603
+ "width": 266
604
+ },
605
+ "position": {
606
+ "x": -626.6563777191027,
607
+ "y": -48.82220889683933
608
+ },
609
+ "positionAbsolute": {
610
+ "x": -626.6563777191027,
611
+ "y": -48.82220889683933
612
+ },
613
+ "resizing": false,
614
+ "selected": false,
615
+ "sourcePosition": "right",
616
+ "style": {
617
+ "height": 176,
618
+ "width": 266
619
+ },
620
+ "targetPosition": "left",
621
+ "type": "noteNode",
622
  "width": 266
623
  },
624
+ {
625
+ "data": {
626
+ "form": {
627
+ "text": "Receives the user's database-related questions and displays the large model's response."
628
+ },
629
+ "label": "Note",
630
+ "name": "N: Interface"
 
 
631
  },
632
+ "dragHandle": ".note-drag-handle",
633
+ "dragging": false,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
634
  "height": 162,
635
+ "id": "Note:PinkTaxesClean",
636
+ "measured": {
637
+ "height": 162,
638
+ "width": 210
639
+ },
640
+ "position": {
641
+ "x": -52.004609812312424,
642
+ "y": 336.95180237635077
643
+ },
644
+ "positionAbsolute": {
645
+ "x": -52.004609812312424,
646
+ "y": 336.95180237635077
647
+ },
648
+ "resizing": false,
649
+ "selected": false,
650
+ "sourcePosition": "right",
651
+ "style": {
652
+ "height": 162,
653
+ "width": 210
654
+ },
655
+ "targetPosition": "left",
656
+ "type": "noteNode",
657
  "width": 210
658
  },
659
+ {
660
+ "data": {
661
+ "form": {
662
+ "text": "Searches for description about meanings of tables and fields."
663
+ },
664
+ "label": "Note",
665
+ "name": "N:DB Description"
 
 
666
  },
667
+ "dragHandle": ".note-drag-handle",
668
+ "dragging": false,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
669
  "height": 128,
670
+ "id": "Note:IcyTreesPeel",
671
+ "measured": {
672
+ "height": 128,
673
+ "width": 251
674
+ },
675
+ "position": {
676
+ "x": 280.8431980571563,
677
+ "y": 394.1463067004627
678
+ },
679
+ "positionAbsolute": {
680
+ "x": 280.8431980571563,
681
+ "y": 394.1463067004627
682
+ },
683
+ "resizing": false,
684
+ "selected": false,
685
+ "sourcePosition": "right",
686
+ "style": {
687
+ "height": 128,
688
+ "width": 251
689
+ },
690
+ "targetPosition": "left",
691
+ "type": "noteNode",
692
  "width": 251
693
  },
694
+ {
695
+ "data": {
696
+ "form": {
697
+ "text": "Searches for samples about question to SQL.\nPlease check this dataset: https://huggingface.co/datasets/InfiniFlow/text2sql"
698
+ },
699
+ "label": "Note",
700
+ "name": "N: Q->SQL"
 
 
701
  },
702
+ "dragHandle": ".note-drag-handle",
703
+ "dragging": false,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
704
  "height": 131,
705
+ "id": "Note:HugeGroupsScream",
706
+ "measured": {
707
+ "height": 131,
708
+ "width": 387
709
+ },
710
+ "position": {
711
+ "x": 606.1206536213404,
712
+ "y": 113.09441734894426
713
+ },
714
+ "positionAbsolute": {
715
+ "x": 606.1206536213404,
716
+ "y": 113.09441734894426
717
+ },
718
+ "resizing": false,
719
+ "selected": false,
720
+ "sourcePosition": "right",
721
+ "style": {
722
+ "height": 131,
723
+ "width": 387
724
+ },
725
+ "targetPosition": "left",
726
+ "type": "noteNode",
727
  "width": 387
728
  },
729
+ {
730
+ "data": {
731
+ "form": {
732
+ "text": "DDL(Data Definition Language).\n\nSearches for relevant database creation statements.\n\nIt should bind with a KB to which DDL is dumped in.\nYou could use 'General' as parsing method and ';' as delimiter."
733
+ },
734
+ "label": "Note",
735
+ "name": "N: DDL"
 
 
736
  },
737
+ "dragHandle": ".note-drag-handle",
738
+ "dragging": false,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
739
  "height": 266,
740
+ "id": "Note:GreenCrewsArrive",
741
+ "measured": {
742
+ "height": 266,
743
+ "width": 266
744
+ },
745
+ "position": {
746
+ "x": 545.3423934788841,
747
+ "y": -166.58872868890683
748
+ },
749
+ "positionAbsolute": {
750
+ "x": 545.3423934788841,
751
+ "y": -166.58872868890683
752
+ },
753
+ "resizing": false,
754
+ "selected": false,
755
+ "sourcePosition": "right",
756
+ "style": {
757
+ "height": 266,
758
+ "width": 266
759
+ },
760
+ "targetPosition": "left",
761
+ "type": "noteNode",
762
  "width": 266
763
  },
764
+ {
765
+ "data": {
766
+ "form": {
767
+ "text": "The large model learns which tables may be available based on the responses from three knowledge bases and converts the user's input into SQL statements."
768
+ },
769
+ "label": "Note",
770
+ "name": "N: Generate SQL"
 
 
771
  },
772
+ "dragHandle": ".note-drag-handle",
773
+ "dragging": false,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
774
  "height": 175,
775
+ "id": "Note:EightTurtlesLike",
776
+ "measured": {
777
+ "height": 175,
778
+ "width": 265
779
+ },
780
+ "position": {
781
+ "x": 222.2150747084395,
782
+ "y": -445.32694170868734
783
+ },
784
+ "positionAbsolute": {
785
+ "x": 222.2150747084395,
786
+ "y": -445.32694170868734
787
+ },
788
+ "resizing": false,
789
+ "selected": false,
790
+ "sourcePosition": "right",
791
+ "style": {
792
+ "height": 175,
793
+ "width": 265
794
+ },
795
+ "targetPosition": "left",
796
+ "type": "noteNode",
797
  "width": 265
798
  },
799
+ {
800
+ "data": {
801
+ "form": {
802
+ "text": "Executes the SQL statement in the database and returns the result.\n\nAfter configuring an accessible database, press 'Test' to ensure the accessibility."
803
+ },
804
+ "label": "Note",
805
+ "name": "N: Execute SQL"
 
 
806
  },
807
+ "dragHandle": ".note-drag-handle",
808
+ "dragging": false,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
809
  "height": 178,
810
+ "id": "Note:FreshKidsTalk",
811
+ "measured": {
812
+ "height": 178,
813
+ "width": 346
814
+ },
815
+ "position": {
816
+ "x": -293.35258272850365,
817
+ "y": -206.3839921107096
818
+ },
819
+ "positionAbsolute": {
820
+ "x": -251.5866574377311,
821
+ "y": -372.2192837064241
822
+ },
823
+ "resizing": false,
824
+ "selected": true,
825
+ "sourcePosition": "right",
826
+ "style": {
827
+ "height": 178,
828
+ "width": 346
829
+ },
830
+ "targetPosition": "left",
831
+ "type": "noteNode",
832
  "width": 346
833
  },
834
+ {
835
+ "data": {
836
+ "form": {
837
+ "database": "",
838
+ "db_type": "mysql",
839
+ "frequencyPenaltyEnabled": true,
840
+ "frequency_penalty": 0.7,
841
+ "host": "",
842
+ "llm_id": "deepseek-chat@DeepSeek",
843
+ "loop": 3,
844
+ "maxTokensEnabled": true,
845
+ "max_tokens": 512,
846
+ "password": "",
847
+ "port": 6630,
848
+ "presencePenaltyEnabled": true,
849
+ "presence_penalty": 0.4,
850
+ "query": [],
851
+ "temperature": 0.1,
852
+ "temperatureEnabled": true,
853
+ "topPEnabled": true,
854
+ "top_n": 30,
855
+ "top_p": 0.3,
856
+ "username": "root"
857
+ },
858
+ "label": "ExeSQL",
859
+ "name": "ExeSQL_0"
860
+ },
861
+ "dragging": false,
862
+ "id": "ExeSQL:QuietRosesRun",
863
+ "measured": {
864
+ "height": 64,
865
+ "width": 200
866
+ },
867
+ "position": {
868
+ "x": -318.61920731731163,
869
+ "y": 3.5145731711609436
870
+ },
871
+ "selected": false,
872
+ "sourcePosition": "right",
873
+ "targetPosition": "left",
874
+ "type": "ragNode"
875
+ }
876
+ ]
877
+ },
878
+ "history": [],
879
+ "messages": [],
880
+ "path": [],
881
+ "reference": []
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
882
  },
 
 
 
 
 
883
  "avatar": ""
884
  }