mirror of
https://github.com/moodle/moodle.git
synced 2025-01-22 08:11:26 +01:00
229 lines
7.7 KiB
PHP
229 lines
7.7 KiB
PHP
<?php
|
|
|
|
/**
|
|
* SQL.PHP
|
|
* This file is include from view.php and print.php
|
|
* @version $Id$
|
|
* @copyright 2003
|
|
**/
|
|
|
|
/// Creating the SQL statements
|
|
|
|
/// Pivot is the field that set the break by groups (category, initial, author name, etc)
|
|
|
|
/// fullpivot indicate if the whole pivot should be compared agasint the db or just the first letter
|
|
/// printpivot indicate if the pivot should be printed or not
|
|
switch ($CFG->dbtype) {
|
|
case 'postgres7':
|
|
$as = 'as';
|
|
break;
|
|
case 'mysql':
|
|
$as = '';
|
|
break;
|
|
}
|
|
|
|
switch ( $sortkey ) {
|
|
case "CREATION":
|
|
$sqlsortkey = "timecreated";
|
|
break;
|
|
|
|
case "UPDATE":
|
|
$sqlsortkey = "timemodified";
|
|
break;
|
|
}
|
|
$sqlsortorder = $sortorder;
|
|
|
|
$fullpivot = 1;
|
|
|
|
$userid = '';
|
|
if ( $USER->id ) {
|
|
$userid = "OR ge.userid = $USER->id";
|
|
}
|
|
switch ($tab) {
|
|
case GLOSSARY_CATEGORY_VIEW:
|
|
if ($hook == GLOSSARY_SHOW_ALL_CATEGORIES ) {
|
|
|
|
$sqlselect = "SELECT gec.id, gc.name $as pivot, ge.*";
|
|
$sqlfrom = "FROM {$CFG->prefix}glossary_entries ge,
|
|
{$CFG->prefix}glossary_entries_categories gec,
|
|
{$CFG->prefix}glossary_categories gc";
|
|
$sqlwhere = "WHERE (ge.glossaryid = '$glossary->id' OR ge.sourceglossaryid = '$glossary->id') AND
|
|
ge.id = gec.entryid AND gc.id = gec.categoryid AND
|
|
(ge.approved != 0 $userid)";
|
|
|
|
if ( $glossary->displayformat == GLOSSARY_FORMAT_CONTINUOUS ) {
|
|
$sqlorderby = ' ORDER BY gc.name, ge.timecreated';
|
|
} else {
|
|
$sqlorderby = ' ORDER BY gc.name, ge.concept';
|
|
}
|
|
|
|
} elseif ($hook == GLOSSARY_SHOW_NOT_CATEGORISED ) {
|
|
|
|
$printpivot = 0;
|
|
$sqlselect = "SELECT concept $as pivot, ge.*";
|
|
$sqlfrom = "FROM {$CFG->prefix}glossary_entries ge";
|
|
$sqlwhere = "WHERE (glossaryid = '$glossary->id' OR sourceglossaryid = '$glossary->id') AND
|
|
(ge.approved != 0 $userid)";
|
|
|
|
|
|
$sqlorderby = ' ORDER BY concept';
|
|
|
|
} else {
|
|
|
|
$printpivot = 0;
|
|
$sqlselect = "SELECT ce.id, c.name $as pivot, ge.*";
|
|
$sqlfrom = "FROM {$CFG->prefix}glossary_entries ge, {$CFG->prefix}glossary_entries_categories ce, {$CFG->prefix}glossary_categories c";
|
|
$sqlwhere = "WHERE ge.id = ce.entryid AND ce.categoryid = $hook AND
|
|
ce.categoryid = c.id AND ge.approved != 0 AND
|
|
(ge.glossaryid = $glossary->id OR ge.sourceglossaryid = $glossary->id) AND
|
|
(ge.approved != 0 $userid)";
|
|
|
|
$sqlorderby = ' ORDER BY c.name, ge.concept';
|
|
|
|
}
|
|
break;
|
|
case GLOSSARY_AUTHOR_VIEW:
|
|
|
|
$where = '';
|
|
switch ($CFG->dbtype) {
|
|
case 'postgres7':
|
|
$usernametoshow = "u.firstname || ' ' || u.lastname";
|
|
if ( $sqlsortkey == 'FIRSTNAME' ) {
|
|
$usernamefield = "u.firstname || ' ' || u.lastname";
|
|
} else {
|
|
$usernamefield = "u.lastname || ' ' || u.firstname";
|
|
}
|
|
$where = "AND substr(ucase($usernamefield),1," . strlen($hook) . ") = '" . strtoupper($hook) . "'";
|
|
break;
|
|
case 'mysql':
|
|
if ( $sqlsortkey == 'FIRSTNAME' ) {
|
|
$usernamefield = "CONCAT(CONCAT(u.firstname,' '), u.lastname)";
|
|
} else {
|
|
$usernamefield = "CONCAT(CONCAT(u.lastname,' '), u.firstname)";
|
|
}
|
|
$where = "AND left(ucase($usernamefield)," . strlen($hook) . ") = '$hook'";
|
|
break;
|
|
}
|
|
if ( $hook == 'ALL' ) {
|
|
$where = '';
|
|
}
|
|
|
|
$sqlselect = "SELECT ge.id, $usernamefield $as pivot, u.id uid, ge.*";
|
|
$sqlfrom = "FROM {$CFG->prefix}glossary_entries ge, {$CFG->prefix}user u";
|
|
$sqlwhere = "WHERE ge.userid = u.id AND
|
|
(ge.approved != 0 $userid)
|
|
$where AND
|
|
(ge.glossaryid = $glossary->id OR ge.sourceglossaryid = $glossary->id)";
|
|
$sqlorderby = "ORDER BY $usernamefield $sqlsortorder, ge.concept";
|
|
break;
|
|
case GLOSSARY_APPROVAL_VIEW:
|
|
$fullpivot = 0;
|
|
$printpivot = 0;
|
|
|
|
$where = '';
|
|
if ($hook != 'ALL' and $hook != 'SPECIAL') {
|
|
switch ($CFG->dbtype) {
|
|
case 'postgres7':
|
|
$where = 'AND substr(ucase(concept),1,' . strlen($hook) . ') = \'' . strtoupper($hook) . '\'';
|
|
break;
|
|
case 'mysql':
|
|
$where = 'AND left(ucase(concept),' . strlen($hook) . ") = '$hook'";
|
|
break;
|
|
}
|
|
}
|
|
|
|
$sqlselect = "SELECT ge.concept $as pivot, ge.*";
|
|
$sqlfrom = "FROM {$CFG->prefix}glossary_entries ge";
|
|
$sqlwhere = "WHERE (ge.glossaryid = $glossary->id OR ge.sourceglossaryid = $glossary->id) AND
|
|
ge.approved = 0 $where";
|
|
|
|
if ( $sqlsortkey ) {
|
|
$sqlorderby = "ORDER BY $sqlsortkey $sqlsortorder";
|
|
} else {
|
|
$sqlorderby = "ORDER BY ge.concept";
|
|
}
|
|
break;
|
|
case GLOSSARY_DATE_VIEW:
|
|
case GLOSSARY_STANDARD_VIEW:
|
|
default:
|
|
$sqlselect = "SELECT ge.concept $as pivot, ge.*";
|
|
$sqlfrom = "FROM {$CFG->prefix}glossary_entries ge";
|
|
|
|
$where = '';
|
|
$fullpivot = 0;
|
|
if ($CFG->dbtype == "postgres7") {
|
|
$LIKE = "ILIKE"; // case-insensitive
|
|
} else {
|
|
$LIKE = "LIKE";
|
|
}
|
|
|
|
switch ( $mode ) {
|
|
case 'search':
|
|
$printpivot = 0;
|
|
$where = "AND ( ge.concept $LIKE '%$hook%'";
|
|
if ( $fullsearch ) {
|
|
$where .= "OR ge.definition $LIKE '%$hook%')";
|
|
} else {
|
|
$where .= ")";
|
|
}
|
|
break;
|
|
|
|
case 'term':
|
|
$printpivot = 0;
|
|
$sqlfrom .= ", {$CFG->prefix}glossary_alias ga";
|
|
$where = "AND ge.id = ga.entryid AND
|
|
(ge.concept = '$hook' OR ga.alias = '$hook' )
|
|
";
|
|
break;
|
|
|
|
case 'entry':
|
|
$printpivot = 0;
|
|
$where = "AND ge.id = $hook";
|
|
break;
|
|
|
|
case 'letter':
|
|
if ($hook != 'ALL' and $hook != 'SPECIAL') {
|
|
switch ($CFG->dbtype) {
|
|
case 'postgres7':
|
|
$where = 'AND substr(ucase(concept),1,' . strlen($hook) . ') = \'' . strtoupper($hook) . '\'';
|
|
break;
|
|
case 'mysql':
|
|
$where = 'AND left(ucase(concept),' . strlen($hook) . ") = '" . strtoupper($hook) . "'";
|
|
break;
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
|
|
$sqlwhere = "WHERE (ge.glossaryid = $glossary->id or ge.sourceglossaryid = $glossary->id) AND
|
|
(ge.approved != 0 $userid)
|
|
$where";
|
|
switch ( $tab ) {
|
|
case GLOSSARY_DATE_VIEW:
|
|
$sqlorderby = "ORDER BY $sqlsortkey $sqlsortorder";
|
|
break;
|
|
|
|
case GLOSSARY_STANDARD_VIEW:
|
|
$sqlorderby = "ORDER BY ge.concept";
|
|
default:
|
|
break;
|
|
}
|
|
break;
|
|
}
|
|
$count = count_records_sql("select count(*) $sqlfrom $sqlwhere");
|
|
$sqllimit = '';
|
|
|
|
if ( $offset >= 0 ) {
|
|
switch ($CFG->dbtype) {
|
|
case 'postgres7':
|
|
$sqllimit = " LIMIT $entriesbypage OFFSET $offset";
|
|
break;
|
|
case 'mysql':
|
|
$sqllimit = " LIMIT $offset, $entriesbypage";
|
|
break;
|
|
}
|
|
}
|
|
|
|
$allentries = get_records_sql("$sqlselect $sqlfrom $sqlwhere $sqlorderby $sqllimit");
|
|
|
|
?>
|