English 中文(简体)
我如何能够从dplyr那里获得详细的数据库错误信息:tbl?
原标题:How might I get detailed database error messages from dplyr::tbl?

Im利用R绘制一些数据,从一个数据库(Stack Exchange数据倾弃,具体如下:

dplyr::tbl(serverfault, 
           dbplyr::sql("
select year(p.CreationDate) year,
       avg(p.AnswerCount*1.0) answers_per_question,
       sum(iif(ClosedDate is null, 0.0, 100.0))/count(*) close_rate
from Posts p
where PostTypeId = 1
group by year(p.CreationDate)
order by year(p.CreationDate)
"))

The query ,但我在R console发现这一错误:

Error: <SQL>  SELECT *
FROM (
select year(p.CreationDate) year,
       avg(p.AnswerCount*1.0) answers_per_question,
       sum(iif(ClosedDate is null, 0.0, 100.0))/count(*) close_rate
from Posts p
where PostTypeId = 1
group by year(p.CreationDate)
order by year(p.CreationDate)
) "zzz11"
WHERE (0 = 1) 
  nanodbc/nanodbc.cpp:1587: 42000: [FreeTDS][SQL Server]Statement(s) could not be prepared. 

我认为,“各国无法做好准备”,这意味着服务器与盘点一样,出于某种原因。 不幸的是,它并没有对什么错误表示任何担忧。 在绕过对借方的询问之后,我注意到,根据错误信息,该点被打上了记分。 服务器在链条的一个图书馆构造下,复制和执行全部盘问,给我这个信息更加翔实的错误信息:

按条款分列的书面记录在意见、在线功能、衍生表格、子类和共同表格表述中无效,除非指明东方木材公司、外国航天公司或意大利法郎。

Now the solution is obvious: remove (or comment out) the order by clause. But where is the detailed error message in the R console? I m using Rstudio, should that matter. If I could get the full exception right next to the code I m working on, it would help me fix bug a lot quicker. (And just to be clear, I get cryptic errors from dplyr::tbl often and typically use binary search debugging to fix them.)

问题回答
library(dbplyr)
library(dplyr)

# Assuming `serverfault` is your database connection
query <- dplyr::tbl(serverfault, 
  dbplyr::sql("
    SELECT 
      YEAR(p.CreationDate) AS year,
      AVG(p.AnswerCount * 1.0) AS answers_per_question,
      SUM(IIF(ClosedDate IS NULL, 0.0, 100.0)) / COUNT(*) AS close_rate
    FROM Posts p
    WHERE PostTypeId = 1
    GROUP BY YEAR(p.CreationDate)
    -- ORDER BY YEAR(p.CreationDate)  -- Commented out the ORDER BY clause
  ")
)

# Display the translated SQL query
show_query(query)

# Execute the query and collect the result
result <- collect(query)

该法典包括显示“频率”功能,显示翻译的QQ。 通过在Kall query中逐条评论ER项目,你可以侧重于清点和理解结构。 在解决任何问题之后,你可以相应地调整问题。





相关问题
How to plot fitted model over observed time series

This is a really really simple question to which I seem to be entirely unable to get a solution. I would like to do a scatter plot of an observed time series in R, and over this I want to plot the ...

REvolution for R

since the latest Ubuntu release (karmic koala), I noticed that the internal R package advertises on start-up the REvolution package. It seems to be a library collection for high-performance matrix ...

R - capturing elements of R output into text files

I am trying to run an analysis by invoking R through the command line as follows: R --no-save < SampleProgram.R > SampleProgram.opt For example, consider the simple R program below: mydata =...

R statistical package: wrapping GOFrame objects

I m trying to generate GOFrame objects to generate a gene ontology mapping in R for unsupported organisms (see http://www.bioconductor.org/packages/release/bioc/vignettes/GOstats/inst/doc/...

Changing the order of dodged bars in ggplot2 barplot

I have a dataframe df.all and I m plotting it in a bar plot with ggplot2 using the code below. I d like to make it so that the order of the dodged bars is flipped. That is, so that the bars labeled "...

Strange error when using sparse matrices and glmnet

I m getting a weird error when training a glmnet regression. invalid class "dgCMatrix" object: length(Dimnames[[2]]) must match Dim[2] It only happens occasionally, and perhaps only under larger ...

Generating non-duplicate combination pairs in R

Sorry for the non-descriptive title but I don t know whether there s a word for what I m trying to achieve. Let s assume that I have a list of names of different classes like c( 1 , 2 , 3 , 4 ) ...

Per panel smoothing in ggplot2

I m plotting a group of curves, using facet in ggplot2. I d like to have a smoother applied to plots where there are enough points to smooth, but not on plots with very few points. In particular I d ...

热门标签