moodle/lib/dmllib.php

472 lines
13 KiB
PHP

<?php // $Id$
///////////////////////////////////////////////////////////////////////////
// //
// NOTICE OF COPYRIGHT //
// //
// Moodle - Modular Object-Oriented Dynamic Learning Environment //
// http://moodle.com //
// //
// Copyright (C) 1999 onwards Martin Dougiamas http://dougiamas.com //
// //
// This program is free software; you can redistribute it and/or modify //
// it under the terms of the GNU General Public License as published by //
// the Free Software Foundation; either version 2 of the License, or //
// (at your option) any later version. //
// //
// This program is distributed in the hope that it will be useful, //
// but WITHOUT ANY WARRANTY; without even the implied warranty of //
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //
// GNU General Public License for more details: //
// //
// http://www.gnu.org/copyleft/gpl.html //
// //
///////////////////////////////////////////////////////////////////////////
/// This library contains all the Data Manipulation Language (DML) functions
/// used to interact with the DB. All the dunctions in this library must be
/// generic and work against the major number of RDBMS possible. This is the
/// list of currently supported and tested DBs: mysql, postresql, mssql, oracle
/// This library is automatically included by Moodle core so you never need to
/// include it yourself.
/// For more info about the functions available in this library, please visit:
/// http://docs.moodle.org/en/DML_functions
/// (feel free to modify, improve and document such page, thanks!)
/// GLOBAL CONSTANTS /////////////////////////////////////////////////////////
require_once($CFG->libdir.'/dmllib_todo.php');
/**
* Bitmask, indicates only :name type parameters are supported by db backend.
*/
define('SQL_PARAMS_NAMED', 1);
/**
* Bitmask, indicates only ? type parameters are supported by db backend.
*/
define('SQL_PARAMS_QM', 2);
/**
* Bitmask, indicates only $1, $2.. type parameters are supported by db backend.
*/
define('SQL_PARAMS_DOLAR', 4);
/**
* Sets up global $DB moodle_database instance
* @return void
*/
function setup_DB() {
global $CFG, $DB;
if (isset($DB)) {
return;
}
if (!isset($CFG->dbuser)) {
$CFG->dbuser = '';
}
if (!isset($CFG->dbpass)) {
$CFG->dbpass = '';
}
if (!isset($CFG->dbname)) {
$CFG->dbname = '';
}
if (!isset($CFG->dbpersist)) {
$CFG->dbpersist = false;
}
if (!isset($CFG->dblibrary)) {
$CFG->dblibrary = 'adodb';
}
if (!isset($CFG->dboptions)) {
$CFG->dboptions = array();
}
if ($CFG->dblibrary == 'adodb') {
$classname = $CFG->dbtype.'_adodb_moodle_database';
require_once($CFG->libdir.'/dml/'.$classname.'.php');
$DB = new $classname();
} else {
error('Not implemented db library yet: '.$CFG->dblibrary);
}
$CFG->dbfamily = $DB->get_dbfamily(); // TODO: BC only for now
$driverstatus = $DB->driver_installed();
if ($driverstatus !== true) {
print_error('dbdriverproblem', 'error', '', $driverstatus);
}
if (debugging('', DEBUG_ALL)) {
// catch errors
ob_start();
} else {
$prevdebug = error_reporting(0);
}
if (!$DB->connect($CFG->dbhost, $CFG->dbuser, $CFG->dbpass, $CFG->dbname, $CFG->dbpersist, $CFG->prefix, $CFG->dboptions)) {
if (debugging('', DEBUG_ALL)) {
if ($dberr = ob_get_contents()) {
$dberr = '<p><em>'.$dberr.'</em></p>';
}
ob_end_clean();
} else {
$dberr = '';
}
if (empty($CFG->noemailever) and !empty($CFG->emailconnectionerrorsto)) {
@mail($CFG->emailconnectionerrorsto,
'WARNING: Database connection error: '.$CFG->wwwroot,
'Connection error: '.$CFG->wwwroot);
}
print_error('dbconnectionfailed', 'error', '', $dberr);
}
if (debugging('', DEBUG__ALL)) {
ob_end_clean();
} else {
error_reporting($prevdebug);
}
return true;
}
/**
* Interface definitions for resultsets returned from database functions.
* This is a simple Iterator with needed recorset closing support.
*
* The differnece from old recorset is that the records are returned
* as objects, not arrays. You should use "foreach ($recordset as $record) {}".
*
* Do not forget to close all recordsets when they are not needed anymore!
*/
interface moodle_recordset extends Iterator {
/**
* Free resources and connections, recordset can not be used anymore.
*/
public function close();
}
/**
* Detail database field information.
* Based on ADOFieldObject.
*/
class database_column_info {
public $name;
public $type; // raw db field type
public $max_length;
public $scale;
public $enums;
public $not_null;
public $primary_key;
public $auto_increment;
public $binary;
public $unsigned;
public $zerofill;
public $has_default;
public $default_value;
public $unique;
public $meta_type; // type as one character
/**
* Contructor
* @param $data mixed object or array with properties
*/
public function database_column_info($data) {
foreach ($data as $key=>$value) {
if (array_key_exists($key, $this)) {
$this->$key = $value;
}
}
}
}
/////// DEPRECATED - works fine
function sql_ilike() {
global $DB;
return $DB->sql_ilike();
}
function sql_fullname($first='firstname', $last='lastname') {
global $DB;
return $DB->sql_fullname($first, $last);
}
function sql_concat() {
global $DB;
$args = func_get_args();
return call_user_func_array(array($DB, 'sql_concat'), $args);
}
function sql_empty() {
global $DB;
return $DB->sql_empty();
}
function sql_substr() {
global $DB;
return $DB->sql_substr();
}
function sql_bitand($int1, $int2) {
global $DB;
return $DB->sql_bitand($int1, $int2);
}
function sql_bitnot($int1) {
global $DB;
return $DB->sql_bitnot($int1);
}
function sql_bitor($int1, $int2) {
global $DB;
return $DB->sql_bitor($int1);
}
function sql_bitxor($int1, $int2) {
global $DB;
return $DB->sql_bitxor($int1, $int2);
}
function sql_cast_char2int($fieldname, $text=false) {
global $DB;
return $DB->sql_cast_char2int($fieldname, $text);
}
function sql_compare_text($fieldname, $numchars=32) {
return sql_order_by_text($fieldname, $numchars);
}
function sql_order_by_text($fieldname, $numchars=32) {
global $DB;
return $DB->sql_order_by_text($fieldname, $numchars);
}
function sql_concat_join($separator="' '", $elements=array()) {
global $DB;
return $DB->sql_concat_join($separator, $elements);
}
function sql_isempty($tablename, $fieldname, $nullablefield, $textfield) {
global $DB;
return $DB->sql_isempty($tablename, $fieldname, $nullablefield, $textfield);
}
function sql_isnotempty($tablename, $fieldname, $nullablefield, $textfield) {
global $DB;
return $DB->sql_isnotempty($tablename, $fieldname, $nullablefield, $textfield);
}
function begin_sql() {
global $DB;
return $DB->begin_sql();
}
function commit_sql() {
global $DB;
return $DB->commit_sql();
}
function rollback_sql() {
global $DB;
return $DB->rollback_sql();
}
function insert_record($table, $dataobject, $returnid=true, $primarykey='id') {
global $DB;
$dataobject = stripslashes_recursive($dataobject);
return $DB->insert_record($table, $dataobject, $returnid);
}
function update_record($table, $dataobject) {
global $DB;
$dataobject = stripslashes_recursive($dataobject);
return $DB->update_record($table, $dataobject, true);
}
function get_records($table, $field='', $value='', $sort='', $fields='*', $limitfrom='', $limitnum='') {
global $DB;
$conditions = array();
if ($field) {
$conditions[$field] = stripslashes_recursive($value);
}
return $DB->get_records($table, $conditions, $sort, $fields, $limitfrom, $limitnum);
}
function get_record($table, $field1, $value1, $field2='', $value2='', $field3='', $value3='', $fields='*') {
global $DB;
$conditions = array();
if ($field1) {
$conditions[$field1] = stripslashes_recursive($value1);
}
if ($field2) {
$conditions[$field2] = stripslashes_recursive($value2);
}
if ($field3) {
$conditions[$field3] = stripslashes_recursive($value3);
}
return $DB->get_record($table, $conditions, $fields);
}
function set_field($table, $newfield, $newvalue, $field1, $value1, $field2='', $value2='', $field3='', $value3='') {
global $DB;
$conditions = array();
if ($field1) {
$conditions[$field1] = stripslashes_recursive($value1);
}
if ($field2) {
$conditions[$field2] = stripslashes_recursive($value2);
}
if ($field3) {
$conditions[$field3] = stripslashes_recursive($value3);
}
return $DB->set_field($table, $newfield, $newvalue, $conditions);
}
function count_records($table, $field1='', $value1='', $field2='', $value2='', $field3='', $value3='') {
global $DB;
$conditions = array();
if ($field1) {
$conditions[$field1] = stripslashes_recursive($value1);
}
if ($field2) {
$conditions[$field2] = stripslashes_recursive($value2);
}
if ($field3) {
$conditions[$field3] = stripslashes_recursive($value3);
}
return $DB->count_records($table, $conditions);
}
function record_exists($table, $field1='', $value1='', $field2='', $value2='', $field3='', $value3='') {
global $DB;
$conditions = array();
if ($field1) {
$conditions[$field1] = stripslashes_recursive($value1);
}
if ($field2) {
$conditions[$field2] = stripslashes_recursive($value2);
}
if ($field3) {
$conditions[$field3] = stripslashes_recursive($value3);
}
return $DB->record_exists($table, $conditions);
}
function delete_records($table, $field1='', $value1='', $field2='', $value2='', $field3='', $value3='') {
global $DB;
$conditions = array();
if ($field1) {
$conditions[$field1] = stripslashes_recursive($value1);
}
if ($field2) {
$conditions[$field2] = stripslashes_recursive($value2);
}
if ($field3) {
$conditions[$field3] = stripslashes_recursive($value3);
}
return $DB->delete_records($table, $conditions);
}
function get_field($table, $return, $field1, $value1, $field2='', $value2='', $field3='', $value3='') {
global $DB;
$conditions = array();
if ($field1) {
$conditions[$field1] = stripslashes_recursive($value1);
}
if ($field2) {
$conditions[$field2] = stripslashes_recursive($value2);
}
if ($field3) {
$conditions[$field3] = stripslashes_recursive($value3);
}
return $DB->get_field($table, $return, $conditions);
}
///// DELETED - must not be used anymore
function configure_dbconnection() {
error('configure_dbconnection() removed');
}
function sql_max($field) {
error('sql_max() removed - use normal sql MAX() instead');
}
function sql_as() {
error('sql_as() removed - do not use AS for tables at all');
}
function sql_paging_limit($page, $recordsperpage) {
error('Function sql_paging_limit() is deprecated. Replace it with the correct use of limitfrom, limitnum parameters');
}
function db_uppercase() {
error('upper() removed - use normal sql UPPER()');
}
function db_lowercase() {
error('upper() removed - use normal sql LOWER()');
}
function modify_database($sqlfile='', $sqlstring='') {
error('modify_database() removed - use new XMLDB functions');
}
function where_clause($field1='', $value1='', $field2='', $value2='', $field3='', $value3='') {
error('where_clause() removed - use new functions with $conditions parameter');
}
function execute_sql_arr($sqlarr, $continue=true, $feedback=true) {
error('execute_sql_arr() removed');
}