⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cycles.query

📁 用JAVA编写的软件度量方面的源码
💻 QUERY
字号:
<#(define recursion-depth-string  (java-call   'javax.swing.JOptionPane   'showInputDialog   (list "The SQL 2 standard does not have recursive queries.This query actually generates a finite depth SQL 2 query.Please specify the recursion depth: 0 <= N <= 5(Maximum cycle length found grows as O(N*N).)")   '(java.lang.Object)))(if (null? recursion-depth-string)    (failwith "Cancelled")  (begin    (define rec-depth (java-call 'java.lang.Integer 'Integer (list recursion-depth-string) '(java.lang.String)))    (set! rec-depth (if (<= rec-depth 0) 0 (if (<= 5 rec-depth) 5 rec-depth)))    (define emit-rec-deps      (lambda (depth)        (if (<= depth 0)            (emit (snapshot-tbl-name "dependency" selected-index))          (begin #>((SELECT *  FROM <#(emit-rec-deps (- depth 1))#> AS d) UNION (SELECT d1.from_package_id, d2.to_package_id  FROM <#(emit-rec-deps (- depth 1))#> AS d1,       <#(emit-rec-deps (- depth 1))#> AS d2  WHERE d1.from_package_id <> d2.to_package_id  AND d1.to_package_id = d2.from_package_id))<# )))) #>SELECT fpn.str AS package, tpn.str AS packageFROM <#(emit-rec-deps rec-depth)#> AS d1,     <#(emit-rec-deps rec-depth)#> AS d2, <#(emit (shared-tbl-name "str"))#> AS fpn, <#(emit (shared-tbl-name "str"))#> AS tpnWHERE d1.from_package_id < d1.to_package_idAND d1.from_package_id = d2.to_package_idAND d2.from_package_id = d1.to_package_idAND d1.from_package_id = fpn.idAND d1.to_package_id = tpn.idORDER BY fpn.str<# )) #>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -