Reports: Ad-hoc database queries

report_customsql
Maintained by Tim at Lone Pine Koala Sanctuary Tim Hunt, at the OU (Perry building) Mahmoud Kassaei
This report plugin allows Administrators to set up arbitrary database queries to act as ad-hoc reports. Reports can be of two types, either run on demand, or scheduled to run automatically. Other users with the right capability can go in and see a list of queries that they have access to. Results can be viewed on-screen or downloaded as CSV.
1891 sites
821 downloads
52 fans
Moodle 2.2, 2.3, 2.4, 2.5

This report, created by The Open University, lets Administrators set up arbitrary SQL select queries that anyone with the appropriate permissions can then run. Reports can be set to be runnable on-demand, or automatically run weekly or monthly.

The results are displayed as a fairly plain HTML table, and can also be downloaded as CSV.

The idea is that this lets you quicly set up ad-hoc reports, without having to create a whole new admin report plugin.

Screenshots

Screenshot #0

Contributors

Tim at Lone Pine Koala Sanctuary
Tim Hunt (Lead maintainer)
at the OU (Perry building)
Mahmoud Kassaei: Developer
Please login to view contributors details and/or to contact them

Comments RSS

Show comments
  • Picture of Pedro Giesel
    Thu, 16 Mar 2017, 10:34 AM
    Hi everyone,
    Is anyone who knows how I can get the students results for all courses?
    I was wondering if I could create a report where I can see the students results for all courses the student is enrolled.

    The student has the OVERVIEW REPORT, where they can access the results of all courses they are enrolled.
    However, the teacher does not have this option to see the results of all courses the student is enrolled.
    Mostly cases, the student is enrolled in the same course as their trainer.

    If someone could help me with that I would be eternally grateful.

    Thank

  • Picture of Marco S
    Sat, 1 Apr 2017, 6:03 PM
    Hi, how to make a visible border table in email? The output table is without bordered lines.
  • Picture of Anderson Hsu
    Thu, 6 Apr 2017, 8:44 PM
    Dear Support Team,
    We can use sql by use Ad-hoc database queries plugin , but after download the result to csv file (refer to the link https://drive.google.com/file/d/0BxriXuT0xeaFRDVoamZLUGhWMDA/view?usp=sharing) , the file content show wrong language as shown as the link: https://drive.google.com/file/d/0BxriXuT0xeaFM1pUbk5naFNkZFE/view?usp=sharing
    How can we adjust the question, and thanks a lot.
  • Picture of JOSE GUILLERMO ROJAS GARRIDO
    Sat, 13 May 2017, 4:43 AM
    can i export .CSV without headers ?
  • Picture of JOSE GUILLERMO ROJAS GARRIDO
    Sat, 13 May 2017, 4:44 AM
    can i export .CSV file without double quotation on the strings ?
  • Tim at Lone Pine Koala Sanctuary
    Tue, 16 May 2017, 10:07 PM
    .CSV format recommends double-quoting all the data. Surely it is not hard to remoev the quotes when you load the file? Similarly, if you don't want the headers, just delete the first line.

    I expect that if you really want to make these changes, it is not hard to change the code of this report.
  • Picture of Daemon Hunt
    Wed, 17 May 2017, 4:59 AM
    Agree. Post-processing the csv or changing the report code is not difficult.
  • Panthers fan
    Thu, 25 May 2017, 9:16 PM
    Tim,

    Question - is it possible in report 1 to call report 2 via a hyperlink? If so (pressing my luck), would it be possible to pass arguments to report 2? Thanks again for a great plugin!

    Richard
  • Tim at Lone Pine Koala Sanctuary
    Thu, 25 May 2017, 10:52 PM
    1. Yes. Just make the value to display in one column of the report look like a URL, and it will automatically be clickable (and read the text on the edit query screen. You probably want to use %%WWWROOT%%.)

    2. Passing parameters to reports probably should work, but does not. E.g. suppose your query has a paramenter called course_name, then a URL like
    https://learn2.open.ac.uk/report/customsql/view.php?id=51&queryparamcourse_name=AA100-16J should work. Unfortunately it does not. We should fix that.
  • Picture of Nicola Ribatti
    Fri, 26 May 2017, 7:33 PM
    Hi to all. I have a question. I Have created a database activity in wich student insert their name, activities and hours of activity. How (with a sql query) can I get the amount of the hours for each student? Thank you very much
  • Panthers fan
    Wed, 21 Jun 2017, 11:46 PM
    Tim,
    I'm writing a report that has a username column that I would like to make into a hyperlink to loginas the particular user. Question - any way to get the required sesskey using SQL commands?
    Thanks again,
    Richard
  • Tim at Lone Pine Koala Sanctuary
    Wed, 21 Jun 2017, 11:54 PM
    I think the reason sesskey exists is precisely to stop that sort of dangerous direct linking.

    However, it would be possible to add another of the %%...%% tokens. E.g. we could have %%SESSKEY%% that gets replaced by the current user's sesskey in the output code. E.g. about here: https://github.com/moodleou/moodle-report_customsql/blob/master/view.php#L153 add a line

    $value = str_replace('%%SESSKEY%%', sesskey(), $value);

    However, I am a bit reluctant to add that to the official version of the plugin.
  • Panthers fan
    Thu, 22 Jun 2017, 12:04 AM
    Re: Adding %%SESSKEY%%

    Tim,
    No worries. I can change in my version. But your answer got me to thinking - Is there a better, safer way to accomplish what I want? Basically, we have a situation where an administrator has to loginas hundreds of users to change some data. The link in the report is just an attempt to save them a few mouse clicks for each user. If there is another way via the plugin to do this, I'm all ears.

    Richard
  • Panthers fan
    Thu, 22 Jun 2017, 12:06 AM
    Re: Adding "Expand all"

    Tim,
    I have written over a hundred reports that I have put into several categories. Question - how would someone add an "Expand all" to the top of the form (like other forms)?

    Richard
  • Tim at Lone Pine Koala Sanctuary
    Thu, 22 Jun 2017, 12:23 AM
    Expand all would be a JavaScript change. Probably not too hard to do.

    Since all the data behind Moodle is in a database, it is quite easy to change things if you can acess the database directly. It is also possible to screw up the data directly, if you make a mistake. So, be careful.
1 2 3 4 5 6 7 8 9 10 11
Please login to post comments