;;;; Programmer: Kevin M. Rosenberg
;;;; Date Started: Apr 2000
;;;;
-;;;; $Id: sql-classes.lisp,v 1.5 2002/10/14 15:25:11 kevin Exp $
+;;;; $Id: sql-classes.lisp,v 1.7 2002/11/07 23:08:00 kevin Exp $
;;;;
;;;; This file, part of UMLisp, is
;;;; Copyright (c) 2000-2002 by Kevin M. Rosenberg, M.D.
ls
:database db))))
+(defun map-ucon-all (fn &key (srl *current-srl*))
+ "Return list of all ucon's"
+ (let ((ls "select distinct CUI,KPFSTR,KCUILRL from MRCON"))
+ (when srl
+ (string-append ls (format nil " where KCUILRL <= ~d" srl)))
+ (string-append ls " order by CUI asc")
+ (with-sql-connection (db)
+ (clsql:map-query
+ nil
+ #'(lambda (cui pfstr cuilrl)
+ (funcall fn
+ (make-instance 'ucon :cui (ensure-integer cui)
+ :pfstr pfstr
+ :lrl (ensure-integer cuilrl))))
+ ls
+ :database db))))
(defun find-udef-cui (cui &key (srl *current-srl*))
ustrs))
ustrs))
+;; Special tables
+
+(defun find-usrl-all ()
+ (let ((usrls '())
+ (tuples (mutex-sql-query "select SAB,SRL from USRL order by SAB desc")))
+ (dolist (tuple tuples)
+ (push (make-instance 'usrl :sab (nth 0 tuple)
+ :srl (ensure-integer (nth 1 tuple))) usrls))
+ usrls))
;;; Multiword lookup and score functions