Scripts relacionados con el acceso y análisis en bases de datos Access.
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.

302 lines
13 KiB

  1. require(RODBC)
  2. sqlDropLast<-function(conn, tablename, droplast=1,dbtype=NULL){
  3. if(sqlTables(conn) %>% filter(TABLE_NAME == "UMID") %>% nrow > 0){dbtype<-"UM"}
  4. if(sqlTables(conn) %>% filter(TABLE_NAME == "OVID") %>% nrow > 0){dbtype<-"OV"}
  5. table<-sqlFetch(conn, tablename)
  6. table<-table[1:(nrow(table)-droplast),]
  7. if (dbtype == "OV"){sqlSave(conn, table, tablename = tablename, safer = F)}
  8. if (dbtype == "UM"){
  9. sqlDrop(conn, tablename)
  10. sqlSave(conn, table, tablename = tablename, safer = F)}
  11. }
  12. sqlInitialize<-function(){
  13. library(tidyverse)
  14. library(RODBC)
  15. library(openxlsx)
  16. ## Conexión a la base de datos
  17. source("ruta_database.R", encoding = "UTF-8")
  18. }
  19. sqlBackUp<-function(dbfile=file,conn=dta,bu.dir=NULL){
  20. if(sqlTables(conn) %>% filter(TABLE_NAME == "UMID") %>% nrow > 0){bu.dir<-"BU_UM"}
  21. if(sqlTables(conn) %>% filter(TABLE_NAME == "OVID") %>% nrow > 0){dbtype<-"BU_OVARIO"}
  22. db=strsplit(dbfile, "/")[[1]]%>% tail(n=1)
  23. bu_path<-gsub(db,bu.dir,dbfile)
  24. if (!dir.exists(bu_path)){
  25. dir.create(bu_path)
  26. print(paste0("Back Up directory ", bu_path, " created"))
  27. }
  28. cp_bu<-paste0(bu_path, "/", format(Sys.time(), format="%Y%m%d"),"-",db)
  29. file.copy(dbfile, cp_bu)
  30. }
  31. sqlShowSamples<-function(conn=dta, nhcs=nhc.test, verb=F, dbtype=NULL){
  32. if(sqlTables(dta) %>% filter(TABLE_NAME == "UMID") %>% nrow > 0){dbtype<-"UM"}
  33. if(sqlTables(dta) %>% filter(TABLE_NAME == "OVID") %>% nrow > 0){dbtype<-"OV"}
  34. if (dbtype == "OV"){
  35. db<-c("dbtables"="SAMPLES", "dbcode"="OVID", "dbsamples"="samples")
  36. query<-paste0("SELECT O.NHC,S.* FROM ",db["dbtables"]," S INNER JOIN ",db["dbcode"]," O ON O.",db["dbcode"],"=S.",db["dbcode"])
  37. }
  38. if (dbtype == "UM"){
  39. db<-c("dbtables"="MUESTRAS", "dbcode"="UMID", "dbsamples"="CODIGO")
  40. query<-paste0("SELECT O.NHC,S.* FROM ",db["dbtables"]," S INNER JOIN ",db["dbcode"]," O ON O.",db["dbcode"],"=S.",db["dbcode"])
  41. }
  42. if (nrow(sqlQuery(conn, query) %>% filter(NHC %in% nhcs)) == 0){
  43. return("No hay muestras de ningún paciente.")
  44. }
  45. if (isFALSE(verb)){
  46. sqlQuery(conn, query) %>% filter(NHC %in% nhcs) %>%
  47. group_by(NHC,UQ(rlang::sym(db["dbcode"]))) %>% summarise(Samples=length(UQ(rlang::sym(db["dbsamples"]))), Names=paste0(UQ(rlang::sym(db["dbsamples"])), collapse = ";")) %>%
  48. merge(data.frame(NHC=nhcs),all=T) %>% mutate(NHC=factor(NHC,levels = nhcs)) %>% arrange(NHC)
  49. }else{
  50. sqlQuery(conn, query) %>% filter(NHC %in% nhcs)
  51. }
  52. }
  53. sqlGenOVID<-function(conn=dta, nhcs=nhc.test, verb=T, sinc=F, dbtype=NULL){
  54. if(sqlTables(dta) %>% filter(TABLE_NAME == "UMID") %>% nrow > 0){dbtype<-"UM"}
  55. if(sqlTables(dta) %>% filter(TABLE_NAME == "OVID") %>% nrow > 0){dbtype<-"OV"}
  56. if (dbtype == "OV"){
  57. db<-c("dbcode"="OVID")
  58. }
  59. if (dbtype == "UM"){
  60. db<-c("dbcode"="UMID")
  61. }
  62. dbid<-sqlFetch(conn,db["dbcode"])
  63. new.nhc<-nhcs[!nhcs %in% dbid$NHC]
  64. next.num<-gsub(db["dbcode"],"",dbid[,db["dbcode"]]) %>% as.numeric %>% max(na.rm=T)+1
  65. last.num<-next.num+(length(new.nhc)-1)
  66. newtab<-data.frame("NHC"=new.nhc, "ID"=sprintf("%s%04d",db["dbcode"],next.num:last.num)) %>% rename(!!db["dbcode"]:="ID")
  67. if(dbtype=="OV"){
  68. dbid<-rbind(dbid,newtab)
  69. }
  70. if(dbtype=="UM"){
  71. dbid<-merge(dbid, newtab, all=T) %>% select(Id,NHC,UMID) %>% arrange(Id)
  72. dbid$Id<-as.numeric(rownames(dbid))
  73. dbid$NHC<-as.numeric(dbid$NHC)
  74. }
  75. rownames(dbid)<-as.character(1:nrow(dbid))
  76. dbid<-filter(dbid, NHC %in% new.nhc) %>% mutate(NHC=as.character(NHC))
  77. if (sinc){
  78. ### !! Atención, esto cambia la base de datos:
  79. sqlSave(conn, dbid, tablename=db["dbcode"], append = T)
  80. print("La base ha sido actualizada.")
  81. }
  82. if (verb){
  83. return(dbid)
  84. }
  85. }
  86. sqlWriteTemp<-function(conn=dta, nhcs=nhc.test, file="queryOV.xlsx", samples.mod=T, clinics.mod=T, dbtype=NULL){
  87. if(sqlTables(dta) %>% filter(TABLE_NAME == "UMID") %>% nrow > 0){dbtype<-"UM"}
  88. if(sqlTables(dta) %>% filter(TABLE_NAME == "OVID") %>% nrow > 0){dbtype<-"OV"}
  89. if (dbtype=="OV"){
  90. upd.ovid<-sqlFetch(conn, "OVID") %>% filter(NHC %in% nhcs)
  91. if (samples.mod){
  92. ## Generar código para las nuevas muestras
  93. samples<-sqlFetch(conn, "SAMPLES")
  94. if(sum(grepl(paste0("OV",Sys.time() %>% format("%y")), samples$samples)) > 0){
  95. next.samp<-gsub(paste0("OV",Sys.time() %>% format("%y")),"", samples$samples) %>% as.numeric %>% max(na.rm=T)+1
  96. }else{
  97. next.samp<-1
  98. }
  99. last.samp<-next.samp+(length(nhcs)-1)
  100. new.samp<-sprintf("OV%s%02d",Sys.time() %>% format("%y"),next.samp:last.samp)
  101. new.samp.df<-merge(sqlFetch(dta,"OVID") %>% merge(data.frame("NHC"=nhcs)), data.frame("NHC"=nhcs, "samples"=new.samp))
  102. samples.exp<-merge(samples %>% slice(0), new.samp.df %>% select(-NHC), all=T) %>% select(colnames(samples)) %>% arrange(samples)
  103. }
  104. if (clinics.mod){
  105. ## Importar los datos clínicos de pacientes existentes y generar nueva entrada par los nuevos
  106. upd.clinics<-sqlFetch(conn, "CLINICS")
  107. ovid.new<-sqlFetch(conn, "OVID") %>% filter(NHC %in% nhcs)
  108. upd.clinics<-merge(ovid.new,upd.clinics, all.x=T, by="OVID")
  109. upd.clinics$NHC<-as.character(upd.clinics$NHC)
  110. for (i in colnames(upd.clinics)[sapply(upd.clinics, lubridate::is.POSIXct)]){upd.clinics[,i]<-as.Date(upd.clinics[,i])}
  111. }
  112. ## Exportar tablas a la plantilla de entrada para su rellenado
  113. wb <- loadWorkbook(file)
  114. writeData(wb, "NHC", upd.ovid)
  115. if (samples.mod){writeData(wb,"samples",samples.exp)}
  116. if (clinics.mod){writeData(wb,"CLINICS",upd.clinics)}
  117. saveWorkbook(wb,file,overwrite = TRUE)
  118. }
  119. if (dbtype=="UM"){
  120. upd.umid<-sqlFetch(conn, "UMID") %>% filter(NHC %in% nhcs)
  121. if (samples.mod){
  122. ## Generar código para las nuevas muestras
  123. samples<-sqlFetch(conn, "MUESTRAS")
  124. if(sum(grepl(paste0("UM",Sys.time() %>% format("%y")), samples$CODIGO)) > 0){
  125. next.samp<-gsub(paste0("UM",Sys.time() %>% format("%y")),"", samples$CODIGO) %>% as.numeric %>% max(na.rm=T)+1
  126. }else{
  127. next.samp<-1
  128. }
  129. last.samp<-next.samp+(length(nhcs)-1)
  130. new.samp<-sprintf("UM%s%02d",Sys.time() %>% format("%y"),next.samp:last.samp)
  131. new.samp.df<-merge(sqlFetch(dta,"UMID") %>% merge(data.frame("NHC"=nhcs)), data.frame("NHC"=nhcs, "CODIGO"=new.samp))
  132. samples.exp<-merge(samples %>% slice(0), new.samp.df %>% select(-NHC), all=T) %>% select(colnames(samples)) %>% arrange(CODIGO)
  133. }
  134. if (clinics.mod){
  135. ## Importar los datos clínicos de pacientes existentes y generar nueva entrada par los nuevos
  136. upd.clinics<-sqlFetch(conn, "CLINICOS")
  137. umid.new<-sqlFetch(conn, "UMID") %>% filter(NHC %in% nhcs)
  138. upd.clinics<-merge(umid.new,upd.clinics %>% select(-Id), all.x=T, by="UMID")
  139. upd.clinics$NHC<-as.character(upd.clinics$NHC)
  140. for (i in colnames(upd.clinics)[sapply(upd.clinics, lubridate::is.POSIXct)]){upd.clinics[,i]<-as.Date(upd.clinics[,i])}
  141. }
  142. ## Exportar tablas a la plantilla de entrada para su rellenado
  143. wb <- loadWorkbook(file)
  144. writeData(wb, "NHC", upd.umid)
  145. if (samples.mod){writeData(wb,"samples",samples.exp)}
  146. if (clinics.mod){writeData(wb,"CLINICS",upd.clinics)}
  147. saveWorkbook(wb,file,overwrite = TRUE)
  148. }
  149. }
  150. sqlSincBD<-function(conn=dta, filetemp="queryOV.xlsx", sinc.samples=F, sinc.clinics=F, dbtype=NULL){
  151. if(sqlTables(dta) %>% filter(TABLE_NAME == "UMID") %>% nrow > 0){dbtype<-"UM"}
  152. if(sqlTables(dta) %>% filter(TABLE_NAME == "OVID") %>% nrow > 0){dbtype<-"OV"}
  153. ## Añadir código de muestra nueva a la base de datos
  154. if (dbtype == "OV"){
  155. print("DB OV detectada")
  156. nsamples<-sqlFetch(conn, "SAMPLES") %>% nrow
  157. upd.samples<-read.xlsx(filetemp, sheet = "samples", detectDates = T)
  158. if (nrow(upd.samples) > 0){rownames(upd.samples)<-(nsamples+1):(nsamples+nrow(upd.samples)) %>% as.character}
  159. if (sinc.samples & nrow(upd.samples) > 0){
  160. upd.samples$IQ_date<-as.Date(upd.samples$IQ_date)
  161. upd.samples$TIL_date<-as.Date(upd.samples$TIL_date)
  162. ### !! Atención, esto cambia la base de datos:
  163. sqlSave(conn, upd.samples, tablename="SAMPLES", append = T, varTypes = c("IQ_date"="date","TIL_date"="date"))
  164. print("Tabla SAMPLES sincronizada.")
  165. }
  166. }
  167. if (dbtype == "UM"){
  168. print("DB UM detectada")
  169. nsamples<-sqlFetch(conn, "MUESTRAS") %>% nrow
  170. upd.samples<-read.xlsx(filetemp, sheet = "samples", detectDates = T)
  171. if (nrow(upd.samples) > 0){rownames(upd.samples)<-(nsamples+1):(nsamples+nrow(upd.samples)) %>% as.character}
  172. if (sinc.samples & nrow(upd.samples) > 0){
  173. upd.samples$FECHA_RECEPCION<-as.Date(upd.samples$FECHA_RECEPCION)
  174. upd.samples$TIPO<-as.character(upd.samples$TIPO)
  175. upd.samples$OBS<-as.character(upd.samples$OBS)
  176. ### !! Atención, esto cambia la base de datos:
  177. sqlSave(conn, upd.samples, tablename="MUESTRAS", append = T, varTypes = c("FECHA_RECEPCION"="Date"), rownames = F)
  178. print("Tabla MUESTRAS sincronizada.")
  179. }
  180. }
  181. ## Añadir datos clínicos modificados a la base de datos
  182. if (dbtype == "OV"){
  183. upd.clinics<-read.xlsx(filetemp, sheet = "CLINICS",detectDates = T)
  184. ovid.mod<-upd.clinics$OVID[upd.clinics$OVID %in% (sqlFetch(dta, "CLINICS") %>% pull(OVID))]
  185. rnames<-sqlFetch(conn, "CLINICS") %>% filter(OVID %in% ovid.mod) %>% rownames
  186. clinics.mod<-upd.clinics %>% filter(OVID %in% ovid.mod) %>% select(-NHC)
  187. rownames(clinics.mod)<-rnames
  188. ### !! Atención, esto cambia la base de datos:
  189. if (sinc.clinics){
  190. fechas<-colnames(clinics.mod)[grepl("DO|date", colnames(clinics.mod))]
  191. for (i in fechas){
  192. clinics.mod[,i]<-as.Date(clinics.mod[,i])
  193. }
  194. sqlUpdate(conn, clinics.mod,"CLINICS")
  195. print("Tabla CLINICS modificada.")
  196. }
  197. }
  198. if (dbtype == "UM"){
  199. upd.clinics<-read.xlsx(filetemp, sheet = "CLINICS",detectDates = T)
  200. umid.mod<-upd.clinics$UMID[upd.clinics$UMID %in% (sqlFetch(dta, "CLINICOS") %>% pull(UMID))]
  201. rnames<-sqlFetch(conn, "CLINICOS") %>% filter(UMID %in% umid.mod) %>% rownames
  202. clinics.mod<-upd.clinics %>% filter(UMID %in% umid.mod) %>% select(-NHC)
  203. rownames(clinics.mod)<-rnames
  204. ### !! Atención, esto cambia la base de datos:
  205. if (sinc.clinics){
  206. fechas<-colnames(clinics.mod)[grepl("date|MET_DX|DoB", colnames(clinics.mod), ignore.case = T)]
  207. for (i in fechas){
  208. clinics.mod[,i]<-as.Date(clinics.mod[,i])
  209. }
  210. sqlUpdate(conn, clinics.mod,"CLINICOS")
  211. print("Tabla CLINICOS modificada.")
  212. }
  213. }
  214. ## Añadir datos clínicos nuevos a la base de datos
  215. if (dbtype == "OV"){
  216. nsamples.clin<-sqlFetch(conn, "CLINICS") %>% nrow
  217. ovid.new<-upd.clinics$OVID[!upd.clinics$OVID %in% (sqlFetch(conn, "CLINICS") %>% pull(OVID))]
  218. clinics.new<-upd.clinics %>% filter(OVID %in% ovid.new) %>% select(-NHC)
  219. if (length(ovid.new) > 0){rownames(clinics.new)<-(nsamples.clin+1):(nsamples.clin+nrow(clinics.new)) %>% as.character}
  220. ### !! Atención, esto cambia la base de datos:
  221. if (sinc.clinics){
  222. fechas<-colnames(clinics.new)[grepl("DO|date", colnames(clinics.new))]
  223. varTypes<-rep("Date",length(fechas))
  224. names(varTypes)<-fechas
  225. for (i in fechas){
  226. clinics.new[,i]<-as.Date(clinics.new[,i])
  227. }
  228. sqlSave(conn, clinics.new, tablename="CLINICS", append = T, varTypes = varTypes)
  229. print("Tabla CLINICS sincronizada.")
  230. }
  231. }
  232. if (dbtype == "UM"){
  233. nsamples.clin<-sqlFetch(conn, "CLINICOS") %>% nrow
  234. umid.new<-upd.clinics$UMID[!upd.clinics$UMID %in% (sqlFetch(conn, "CLINICOS") %>% pull(UMID))]
  235. clinics.new<-upd.clinics %>% filter(UMID %in% umid.new) %>% select(-NHC)
  236. if (length(umid.new) > 0){rownames(clinics.new)<-(nsamples.clin+1):(nsamples.clin+nrow(clinics.new)) %>% as.character}
  237. ### !! Atención, esto cambia la base de datos:
  238. if (sinc.clinics){
  239. fechas<-colnames(clinics.new)[grepl("date|MET_DX|DoB", colnames(clinics.new), ignore.case = T)]
  240. varTypes<-rep("Date",length(fechas))
  241. names(varTypes)<-fechas
  242. for (i in fechas){
  243. clinics.new[,i]<-as.Date(clinics.new[,i])
  244. }
  245. sqlSave(conn, clinics.new, tablename="CLINICOS", append = T, varTypes = varTypes)
  246. print("Tabla CLINICOS sincronizada.")
  247. }
  248. }
  249. }
  250. sqlMultiSamples<-function(kbl=F, NHC=F, full=F){
  251. query<-sqlQuery(dta, "SELECT U.UMID,U.NHC,M.FECHA_RECEPCION,M.TIPO,M.CODIGO,C.CODIGO,R.CODIGO,R.ESTADO
  252. FROM ((UMID U
  253. LEFT OUTER JOIN MUESTRAS M ON U.UMID=M.UMID)
  254. LEFT OUTER JOIN CNAG C ON M.CODIGO=C.CODIGO)
  255. LEFT OUTER JOIN RNADNA R ON M.CODIGO=R.CODIGO") %>% rename("CNAG"="CODIGO.1","RNADNA"="CODIGO.2")
  256. if (full==F){query<- query %>% filter(!is.na(CODIGO))}
  257. if (NHC==F){query<- query %>% select(-NHC)}
  258. query<-query %>% mutate(
  259. CNAG=case_when(!is.na(CNAG)~"X",TRUE~""),
  260. RNADNA=case_when((!is.na(RNADNA) & (ESTADO=="ENV"))~"X",
  261. (!is.na(RNADNA) & (is.na(ESTADO)))~".",
  262. TRUE~"")
  263. ) %>% select(-ESTADO)
  264. if (kbl==T){
  265. query %>% kableExtra::kbl() %>% kableExtra::kable_styling(full_width = F, bootstrap_options = c("striped"))
  266. }else{
  267. return(query)
  268. }
  269. }