You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

DB Assistant.json 60KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931
  1. {
  2. "id": 6,
  3. "title": "DB Assistant",
  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",
  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": 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. }