moodle笔记之-数据库操作
<?php
require_once('../config.php'); // config.php under root folder
require_once($CFG->dirroot .'/course/lib.php');
require_once($CFG->libdir .'/filelib.php');
//redirect_if_major_upgrade_required();
参数详解
define('IGNORE_MISSING', 0);//兼容模式如果没有找到记录返回false,显示调试警告如果多个记录发现
define('IGNORE_MULTIPLE', 1);//与 IGNORE_MISSING相似但如果多个记录发现不显示调试警告,不建议使用
define('MUST_EXIST', 2);//显示一个记录必须存!在如果发现没有记录或者多个记录会抛出异常
$conditions:可选的数组默认为null
$sort:可选排序默认为空
$fields:要查询的字段(可以是*或者X和字段名;多个用,隔开)。默认为*
$limitfrom=0:返回记录的子集,开始在这一点上(可选)默认为0
$limitnum:返回一个许多记录组成的子集总共(可选,如果$ limitfrom设置那么它也是必需的)默认为0
$table:要查询的表名
$select:要查询的sql片段
$params:一个sql字段值的参数组
//看到有多少匹配给定标准的记录
//
//1 count_records:统计函数相当于:select count(*) from mdl_user;
//$DB->count_records($table, array $conditions=null)
echo $DB->count_records('user').'<br><br>'; // 查询有多少用户
// $DB->count_records_select($table, $select, array $params=null, $countitem="COUNT('x')")
// 注意:COUNT('x')等同于COUNT(*)
echo $DB->count_records_select('user', 'firstname=?', array('同学'),"COUNT('x')").'<br><br>';
//$DB->count_records_sql($sql, array $params=null)
$sql_1="select count(id)from {user} where firstname = ? ";
echo '<pre>';
echo $DB->count_records_sql($sql_1, array('同学')) .'<br />';
//
//获取单个记录 只能显示一个记录相当于加了个limit 1
//
//2 get_record($table, array $conditions, $fields='*', $strictness=IGNORE_MISSING)
//所有在函数中的条件参数都用array(字段名=>字段值)
$person = $DB->get_record('user', array('firstname'=>'li'));//如果数据库中与两条相同的数据只显示一条
//get_record :相当于select * from 表名 where firstname='li' limit 1;
$aaa=$DB->get_record('user', array('id' =>2), 'lastname,firstname', MUST_EXIST);
//相当于select lastname,firstname from mdl_user where id =2 limit 1;
//var_dump($aaa);
//3 $DB->get_record_select($table, $select, array $params=null, $fields='*', $strictness=IGNORE_MISSING)
$record = $DB->get_record_select('user', "id = ?", array(2),'lastname,firstname',IGNORE_MISSING);
//var_dump($record);
//相当于select lastname,firstname from mdl_user where id =2 limit 2;
echo '-------------------------------------------------------------------------------------------'.'<br />';
//
//4 当使用xxx_sql()函数,表名之间必须附上花括号
//
$user = $DB->get_record_sql('select * from {user} where id = ?', array(2));
//var_dump($user);
//select * from {user} where id = 2 limit 1;
echo '<br />';
//5 $DB->get_record_sql($sql, array $params=null, $strictness=IGNORE_MISSING);
//所有在函数$ params参数是用于在SQL语句中填充占位符的值的数组。两个问号和命名占位符可以使用。需要注意的是名为PARAMS 必须是唯一的,即使传递的值是相同的。
//问号占位符
$DB->get_record_sql('SELECT * FROM {user} WHERE firstname = ? AND lastname = ?',array('Martin', 'Dougiamas'));
//问号占位符
$DB->get_record_sql('SELECT * FROM {user} WHERE firstname = :firstname AND lastname = :lastname',array('firstname'=>'Martin', 'lastname'=>'Dougiamas'));
///
//得到一个散列数组记录 可以显示多个记录
//
//6 $DB->get_records($table, array $conditions=null, $sort='', $fields='*', $limitfrom=0, $limitnum=0)
$params_a = array('lastname' => '高永红', 'firstname' =>'同学');
$instances = $DB->get_records('user', $params_a, 'lastname, id desc','id,lastname,firstname');//desc倒序 asc正序
echo '<pre>';
var_dump($instances);
//7 $DB->get_records_select($table, $select, array $params=null, $sort='', $fields='*', $limitfrom=0, $limitnum=0)
$ccc=$DB->get_records_select('user', 'lastname=?and firstname=?', array('高永红','同学'), 'id desc', 'id,lastname,firstname', 0, 0);
var_dump($ccc);
//8 $DB->get_records_sql($sql, array $params=null, $limitfrom=0, $limitnum=0);的出来的结果是数组里面套对象并且每个对象还对应其id值,有段哦少记录显示多少出来如:
/*array(52) {
[7]=>
object(stdClass)#179 (53) {
["id"]=>
string(1) "7"
.....
注意get_record_sql不管查到几条数据只显示一条数据
他的语法如下
*/
$bbb=$DB->get_records_sql('select * from {user} where firstname=?', array('同学'),0,0);
//9 $DB->get_records_list($table, $field, array $values, $sort='', $fields='*', $limitfrom='', $limitnum='')
$re = $DB->get_records_list('user', 'id', array(2, 5));
//var_dump($re);
//相当于SELECT * FROM {} WHERE course IN (?,?)
echo'<br />--------------------------------------------------------------------------------------------<br />';
//
//获取数据一个关联数组的键/值对
//
//
// 10 $DB->get_records_menu($table,array$conditions=null,$sort='',$fields='*',$limitfrom=0,$limitnum=0)
// 如果满足所有给定的条件,那么会把前两列的记录作为一个关联数组,。
$ddd=$DB->get_records_menu('user',array('lastname' => '高永红', 'firstname' =>'同学'),'id desc','id,lastname,firstname',0,0);
/*
结果如下:
array(2) {
[59]=>
string(9) "高永红"
[58]=>
string(9) "高永红"
}
*/
$ddd=$DB->get_records_menu('user',array('lastname' => '高永红', 'firstname' =>'同学'),'id desc','username,email,lastname,firstname',0,0);
/*
array(2) {
[11111111]=>
string(15) "aaaaaaaa@qq.com"
[29481804]=>
string(15) "29481804@qq.com"
}
*/
//可以看出不管查询出多少列(字段)只去前两列并且将第一列的作为键第二列作为值组成一个新数组
//
//11 get_records_select_menu($table, $select, array $params=null, $sort='', $fields='*', $limitfrom=0, $limitnum=0)
//
$eee=$DB->get_records_select_menu('user','lastname=? and firstname=?',array('高永红', '同学'),'id desc','username,email,lastname,firstname',0,0);
/*
array(2) {
[11111111]=>
string(15) "aaaaaaaa@qq.com"
[29481804]=>
string(15) "29481804@qq.com"
}
*/
//
//12 $DB->get_records_sql_menu($sql, array $params=null, $limitfrom=0, $limitnum=0)
//
$sql_f='select username,email,lastname,firstname from {user} where lastname=? and firstname = ?';
$fff=$DB->get_records_sql_menu($sql_f, array('高永红', '同学'),0,0);
/*
array(2) {
[11111111]=>
string(15) "aaaaaaaa@qq.com"
[29481804]=>
string(15) "29481804@qq.com"
}
*/
//
//如果存在一条记录返回true不存在则返回false
//
//13 $DB->record_exists($table, array $conditions=null)
$ggg=$DB->record_exists('user', array('id'=>2));
var_dump($ggg);
//
//14 $DB->record_exists_select($table, $select, array $params=null)
$hhh=$DB->record_exists_select('user', 'id=?', array(2));
var_dump($hhh);
//15 $DB->record_exists_sql($sql, array $params=null) (下面这句的sql语句可能不太正确);
$sql_15="select id,lastname,country from {user} where firstname = ? group by country having count(id)>1";
echo '<pre>';
$result15=$DB->record_exists_sql($sql_15, array('同学')) ;
var_dump($result15);
//
//得到一个记录的某个特定字段值
//
//16 $DB->get_field($table, $return, array $conditions, $strictness=IGNORE_MISSING)
// 注意; $conditions查询出来的值必须是单条记录多条记录会报错(可以这样认为他们两个都是独一无二的)
// 下面这个例子就是从一个叫张丽的字段中查出对应的id
$iii=$DB->get_field('user', 'id', array('lastname'=>'张丽'),IGNORE_MISSING);
var_dump($iii);
//17 $DB->get_field_select($table, $return, $select, array $params=null, $strictness=IGNORE_MISSING)
$jjj=$DB->get_field_select('user', 'id', 'lastname=?', array('张丽'), IGNORE_MISSING);
var_dump($jjj);
//
//18 $DB->get_field_sql($sql, array $params=null, $strictness=IGNORE_MISSING)
echo $DB->get_field_sql("select id from {user} where lastname=?", array('张丽'), IGNORE_MISSING).'<br>';
//
//从各个记录中得到一个特定的字段值
//
//19 $DB->get_fieldset_select($table, $return, $select, array $params=null)
$kkk=$DB->get_fieldset_select('user', 'id','firstname=?', array('同学'));
//var_dump($kkk);
//20 $DB->get_fieldset_sql($sql, array $params=null)
$lll=$DB->get_fieldset_sql('select id from {user} where firstname=?', array('同学'));
//var_dump($lll);
//
//达到条件时在数据库中为某个设置特定字段设置新值(修改字段值)修改成功返回true
//
//21 $DB->set_field($table, $newfield, $newvalue, array $conditions=null)
$mmm=$DB->set_field('user', 'username', 'myusername', array('username'=>'11111111'));
var_dump($mmm);
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//+ +
//+ +
//+ 删除数据 +
//+ +
//+ +
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//删除单条数据
//22 $DB->delete_records($table, array $conditions=null)
$DB->delete_records('user', array('id'=>60));
//23 $DB->delete_records_select($table, $select, array $params=null)
$DB->delete_records_select('user', 'id=?', array(61));
//删除多条数据
//24 delete_records_list($table, $field, array $values)
//删除一个记录从表中(哪个表)一个字段匹配的值列表
//$field:搜索要删除的的字段名
//array $values 要删除的该字段的值的数组
$DB->delete_records_list('user', 'id', array(65,67,68));
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
// +
// +
// 插入数据 +
// +
// +
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//$DB->insert_record($table, $dataobject, $returnid=true, $bulk=false)
//$dataobject:一个或多个字段的值记录的数据对象
//$returnid:新创建的记录条目的id应该返回?如果这个选项不是请求然后返回true / false
// $bulk 是否重复插入
// 返回true或者新的id
//
/*
$person = new StdClass();
$person->auth = 'manual';
$person->confirmed = 1;
$person->mnethostid = 1;
$person->lastlogin = time();
$person->currentlogin = time();
$person->username = "lichihua1";
$person->password = hash_internal_user_password('a173512');
//$person->idnumber = $person->username;
$person->firstname = "李四";
$person->lastname = "老师";
$person->email = "firstname@gmail.com";
$person->city = "蓬溪";
$person->country = "CN";
$person->lang = "zh_cn";
echo $person->id = $DB->insert_record('user', $person);
//插入前insert_record会将上面的数据对象转化成数组$dataobject = (array)$person;
get_columns($table)方法会将表的字段信息展示出来然后用foreach循环和上面对象转换的进行比较筛选然过滤后在返回来
然后normalise_value()方法会将返回回来的数组的字段对应的键和值进行转换后再次返回回来
最后再将上面处理的放入insert_record_raw()方法中 进行插入操作
*/
echo '1111111111111111111111111111111111111111<br>';
$record = new stdClass();
$record->auth = 'manual';
$record->confirmed = 1;
$record->mnethostid = 1;
$record->lastlogin = time();
$record->currentlogin = time();
$record->username = "lichihua4";
$record->firstname = "李四4";
$record->lastname = "老师";
$record->password = hash_internal_user_password('123');
//$lastinsertid = $DB->insert_record('user', $record, false);//成功不返回id返回true的操作默认是返回id的
//$lastinsertid = $DB->insert_record('user', $record);//成功返回id的操作默认是返回id的
//var_dump($lastinsertid);
/*
$record1 = new stdClass();
$record1->name = 'overview';
$record1->displayorder = '10000';
$record2 = new stdClass();
$record2->name = 'overview';
$record2->displayorder = '10000';
$records = array($record1, $record2);
$lastinsertid = $DB->insert_records('quiz_report', $records);
*/
/*
//insert_record_raw($table, $params, $returnid=true, $bulk=false, $customsequence=false)
//这个是插入的过程函数不会用到它
//插入新记录到数据库,尽可能快,没有安全检查,lob不支持
//$params:数据记录的对象或数组
//$returnid:返回它的插入记录(return it of inserted record)
// $bulk:重复插入的预期
//$customsequence:如果“id”被包括在$params参数里,那么禁用$returnid
//返回值true或者插入时获取的id即$customsequence为true是返回id值false是返回true
//
//工作流程:1如果参数不是数组那么经他转化成数组
//2如果$customsequence为真判断$params中是否有id如果若果没有抛出错误提示并且将$customsequence的值改为false。如果$customsequence为假按么销毁$params中的id(unset($params['id'])
//3、判断参数是否为空为空的话抛出错误提示
//4、//取得数组的键名并用,将其拼接成字符串
// $qms = array_fill(0, count($params), '?');//用问号填充数组填充次数为参数的个数
// $qms = implode(',', $qms);//将?填充好的数组之后,在用,链接成一个字符串
//这时的sql语句为INSERT INTO 表名 (字段名-参数1,参数2,参数3) VALUES(?,?,?...)
//5 list($sql, $params, $type) = $this->fix_sql_params($sql, $params);将处理好的sql语句参数等依次分别付给左边变量。。。执行插入操作
*/
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//+ +
//+ +
//+ 修改(数据)记录 +
//+ +
//+ +
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//$DB->update_record($table, $dataobject, $bulk=false)
$dataobject = new stdClass();
$dataobject->id = 73;
$dataobject->username = "lichihua004";
$dataobject->firstname = "李四004";
$dataobject->password = hash_internal_user_password('00123');
//$DB->update_record('user', $dataobject, false);
//如果要使用任意的sql执行更复杂的更新
//$DB->execute($sql, array $parms=null)
//不要使用这个使数据库结构变化,用database_manager方法代替!
//database_manager
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//+ +
//+ +
//+ 使用记录集 +
//+ +
//+ +
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
/*
其中从DB中检索的记录的数量高,get_records_xxx()函数上述远非最佳的,因为它们加载在存储器中的所有记录在同一时间。在这种情况下,强烈建议使用这些get_recordset_xxx()函数来代替,其中用一个很好的机制来遍历所有的目标记录,并节省了大量的内存。只有一件事是绝对重要的:不要忘记使用后关闭该记录集! (这将释放在RDBMS大量的资源)。下面是遍历使用get_recordset_xxx()函数记录的一般方式:
这是一般方法遍历记录使用get_recordset_xxx()函数:
$rs=$DB->get_recordset(....){
foreach($rsas$record){
// Do whatever you want with this record
}
$rs->close();// Don't forget to close the recordset!
这是可用功能列表(100%搭配get_records_xxx()以上):
o $DB->get_recordset($table,array$conditions=null,$sort='',$fields='*',$limitfrom=0,$limitnum=0)
/// Get a number of records as a moodle_recordset where all the given conditions met.
o $DB->get_recordset_select($table,$select,array$params=null,$sort='',$fields='*',$limitfrom=0,$limitnum=0)
/// Get a number of records as a moodle_recordset which match a particular WHERE clause.
o $DB->get_recordset_sql($sql,array$params=null,$limitfrom=0,$limitnum=0);
/// Get a number of records as a moodle_recordset using a SQL statement.
o $DB->get_recordset_list($table,$field='',$values='',$sort='',$fields='*',$limitfrom='',$limitnum='')
/// Get a number of records as a moodle_recordset where one field matches one list of values.
与get_record功能,您不能使用rs = = true或$!空(rs)来确定任何记录被发现。记录集这样的实现标准的PHP迭代器接口(http://uk.php.net/manual/en/class.iterator.php)
所以,
不像get_record功能,你不能使用$rs == true 或者 !empty($rs),以确定是否发现任何记录。记录集实现标准的PHP Iterator接口(http://uk.php.net/manual/en/class.iterator.php) 所以
if($rs->valid()){
// The recordset contains records.
}
*/
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//+ +
//+ +
//+ 委托交易(事务处理) +
//+ +
//+ +
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
/*
//启动事物
$transaction=$DB->start_delegated_transaction();
//提交?
$transaction->allow_commit();
//回滚
$transaction->rollback($e);
*/
//例子
/*
global $DB;
try {
$transaction = $DB->start_delegated_transaction();
// Insert a record
$DB->insert_record('foo', $object);
$DB->insert_record('bar', $otherobject);
// Assuming the both inserts work, we get to the following line.
$transaction->allow_commit();
} catch(Exception $e) {
$transaction->rollback($e);
}
*/
//$DB->set_debug(true) 调试功能
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//+ +
//+ +
//+ SQL兼容性函数 +
//+ +
//+ +
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//看不懂省略
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//+ +
//+ +
//+ 特殊情况 :课程获取 +
//+ +
//+ +
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//注意:在2.51版本以上生效
//get_course($fields)比如你想要根据课程id查这门课程的记录那么用get_course($courseid)替换:$course = $DB->get_record('course', array('id' => $courseid), '*', MUST_EXIST);
//get_courses(此括号里无参数):这个函数是获取当前所有的课程
$courses = get_courses();
var_dump($courses);
echo'++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++<br />';
$capabilityname='plugintype/pluginname:capabilityname';
$pattern='|[/:]|';
$arr=preg_split($pattern,$capabilityname);//这里是用/或者:分割字符串
var_dump($arr);
list($type, $name, $capname) = preg_split('|[/:]|', $capabilityname);
var_dump($type);
echo '';
//list()把数组中的值付给一些变量
//preg_split(正则模式,要处理的字符串) — 通过一个正则表达式分隔字符串
echo'++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++<br />';
moodle笔记之-数据库操作的更多相关文章
- ThinkPHP 学习笔记 ( 三 ) 数据库操作之数据表模型和基础模型 ( Model )
//TP 恶补ing... 一.定义数据表模型 1.模型映射 要测试数据库是否正常连接,最直接的办法就是在当前控制器中实例化数据表,然后使用 dump 函数输出,查看数据库的链接状态.代码: publ ...
- Symfony2学习笔记之数据库操作
数据库和Doctrine让我们来面对这个对于任何应用程序来说最为普遍最具挑战性的任务,从数据库中读取和持久化数据信息.幸运的是,Symfony和Doctrine进行了集成,Doctrine类库全部目标 ...
- django 笔记4 数据库操作
django操作数据库 orm操作 对应关系 models.tb.objects.filter(id__gt=) models.tb.objects.filter(id=) models.tb.obj ...
- Laravel 学习笔记之数据库操作——Eloquent ORM
1. 时间戳 默认情况下在使用ORM操作数据库进行添加.修改数据时, created_at 和 updated_at列会自动存在于数据表中,并显示的是 ‘2017’格式,如果想以 Unix时间戳格式存 ...
- ThinkPHP 学习笔记 ( 四 ) 数据库操作之关联模型 ( RelationMondel ) 和高级模型 ( AdvModel )
一.关联模型 ( RelationMondel ) 1.数据查询 ① HAS_ONE 查询 创建两张数据表评论表和文章表: tpk_comment , tpk_article .评论和文章的对应关系为 ...
- Hive笔记之数据库操作
创建数据库 hive创建数据库的最简单写法和mysql差不多: create database foo; 仅当名为foo的数据库当前不存在时才创建: create database if not ex ...
- Flas-SQLAchemy数据库操作使用学习笔记
Flas-SQLAchemy数据库操作使用学习笔记 Flask-SQLALchemy 是一个给你的应用添加 SQLALchemy 支持的 Flask 扩展.SQLALchemy 是Python语言的S ...
- golang学习笔记16 beego orm 数据库操作
golang学习笔记16 beego orm 数据库操作 beego ORM 是一个强大的 Go 语言 ORM 框架.她的灵感主要来自 Django ORM 和 SQLAlchemy. 目前该框架仍处 ...
- Python学习笔记:sqlite3(sqlite数据库操作)
对于数据库的操作,Python中可以通过下载一些对应的三方插件和对应的数据库来实现数据库的操作,但是这样不免使得Python程序变得更加复杂了.如果只是想要使用数据库,又不想下载一些不必要的插件和辅助 ...
随机推荐
- 怎么让猫吃辣椒 转载自 xiaotie
典故: 某日,毛.周.刘三人聊天. 毛:怎么能让猫自愿吃辣椒? 刘:掐着脖子灌. 毛:强迫不是自愿. 周: 先饿几天,再混到猫爱吃的东西里. 毛:欺骗不是自愿.把辣椒涂到猫肛门上,它就会自己去舔了. ...
- Python实现LDAP用户名密码验证
网上借鉴了不少东西,下面是python代码,备份后用. 思路,因为每个用户的组都不一样,这样就导致了dn不一致的情况, 据需要先根据用户名获取该用户的dn,然后再bind用户名和密码进行验证. 反正是 ...
- 自然语言处理(NLP)常用开源工具总结(转)
..................................内容纯转发+收藏................................... 学习自然语言这一段时间以来接触和听说了好多开 ...
- [转]Avoiding GDB Signal Noise.
原文:http://peeterjoot.wordpress.com/2010/07/07/avoiding-gdb-signal-noise/ A quick note for future ref ...
- Hibernate:如何映射聚合?
Hibernate:如何映射聚合? 目录 背景映射聚合聚合模型映射配置测试备注 背景返回目录 DDD 是在 Hibernate 之后发现的概念,Hibernate 如何映射 DDD 中的聚合呢?本文给 ...
- JavaScript之创建对象
不定义JQuery插件,不要说会JQuery 一:导言 有些WEB开发者,会引用一个JQuery类库,然后在网页上写一写$("#"),$("."),写了几年就对 ...
- Github官方app的账户身份验证的实现
作为github上被fork最多,被star最多的Android项目,实在是没有理由不让我去学习学习的.这篇文章是关于其账户身份验证模块的实现的.如果你对此有兴趣,请移步到我的blog,地址如下: 地 ...
- 我的API HOOK库
API HOOK有两种做法,一种是SetWindowHookEx,简单易用,但如果做其它的HOOK,如HOOK OpenProcess,就需要修改内存地址了,内存地址可以通过WriteProcessM ...
- JPA 批注参考
body, p, th, td, li, ul, ol, h1, h2, h3, h4, h5, h6, pre { font-family: simsun; line-height: 1.4; } ...
- java分割excel文件可用jxl
excel导入是经常使用到的功能,如果文件数据量大的话还是建议分割后导入,java常用的API是poi和jxl,我采用的是jxl,那么让我们来看下怎么用jxl来实现分割. 需要在pom中导入jxl的包 ...