php utility框架,Database Utility Class

数据库实用程序类包含帮助您管理数据库的方法。

初始化实用程序类

使用数据库实用程序检索数据库名称列表

确定数据库是否存在

优化表格

修理一张桌子

优化数据库

将查询结果导出为CSV文件

将查询结果导出为XML文档

备份您的数据库数据库备份注释

用法示例

设置备份首选项

备份首选项说明

类参考

初始化实用程序类

重要

为了初始化Utility类,您的数据库驱动程序必须已经运行,因为utilities类依赖它。

按如下方式加载Utility类:

$this->load->dbutil();

如果您要管理的数据库不是默认数据库,则还可以将另一个数据库对象传递给数据库实用程序加载器:

$this->myutil = $this->load->dbutil($this->other_db, TRUE);

在上面的例子中,我们传递一个自定义数据库对象作为第一个参数,然后告诉它返回dbutil对象,而不是直接指定给它$this->dbutil。

注意

这两个参数都可以单独使用,只要传递一个空值作为第一个参数就可以跳过它。

初始化后,您将使用该$this->dbutil对象访问方法:

$this->dbutil->some_method();

使用数据库实用程序

检索数据库名称列表

返回一组数据库名称:

$dbs = $this->dbutil->list_databases();foreach ($dbs as $db){

echo $db;}

确定数据库是否存在

有时候知道某个特定数据库是否存在会很有帮助。返回一个布尔值TRUE / FALSE。用法示例:

if ($this->dbutil->database_exists('database_name')){        // some code...}

注意

将database_name替换为您正在查找的数据库的名称。此方法区分大小写。

优化表格

允许您使用第一个参数中指定的表名来优化表。根据成功或失败返回TRUE / FALSE:

if ($this->dbutil->optimize_table('table_name')){

echo 'Success!';}

注意

并非所有数据库平台都支持表格优化 它主要用于MySQL。

修复一张表格

允许您使用第一个参数中指定的表名来修复表格。根据成功或失败返回TRUE / FALSE:

if ($this->dbutil->repair_table('table_name')){

echo 'Success!';}

注意

并非所有的数据库平台都支持表格修复。

优化数据库

允许您优化您的数据库类当前连接到的数据库。返回包含DB状态消息的数组或失败时返回FALSE。

$result = $this->dbutil->optimize_database();if ($result !== FALSE){        print_r($result);}

注意

并非所有数据库平台都支持数据库优化 它主要用于MySQL。

将查询结果导出为CSV文件

允许您从查询结果中生成CSV文件。该方法的第一个参数必须包含查询中的结果对象。例:

$this->load->dbutil();$query = $this->db->query("SELECT * FROM mytable");echo $this->dbutil->csv_from_result($query);

第二,第三和第四个参数允许您分别设置分隔符换行符和外壳字符。默认情况下,逗号用作分隔符,“n”用作新行,双引号用作机箱。例:

$delimiter = ",";$newline = "\r\n";$enclosure = '"';echo $this->dbutil->csv_from_result($query, $delimiter, $newline, $enclosure);

重要

此方法不会为您写入CSV文件。它只是创建CSV布局。如果您需要使用文件助手来编写文件。

将查询结果导出为XML文档

允许您从查询结果生成XML文件。第一个参数需要查询结果对象,第二个参数可能包含一个可选的config参数数组。例:

$this->load->dbutil();

$query = $this->db->query("SELECT * FROM mytable");

$config = array (

'root'          => 'root',

'element'       => 'element',

'newline'       => "\n",

'tab'           => "\t"

);

echo $this->dbutil->xml_from_result($query, $config);

重要

此方法不会为您编写XML文件。它只是创建XML布局。如果您需要使用文件助手来编写文件。

备份您的数据库

数据库备份注释

允许您备份完整数据库或单个表格。备份数据可以使用Zip或Gzip格式进行压缩。

注意

此功能仅适用于MySQL和Interbase / Firebird数据库。

注意

对于Interbase / Firebird数据库,备份文件名是唯一的参数。

$this->dbutil->backup(‘db_backup_filename’);

注意

由于PHP可用的执行时间和内存有限,因此可能无法备份非常大的数据库。如果数据库非常大,则可能需要通过命令行直接从SQL服务器进行备份,或者如果您没有root权限,请让您的服务器管理员为您执行备份。

用法示例

// Load the DB utility class

$this->load->dbutil();

// Backup your entire database and assign it to a variable

$backup = $this->dbutil->backup();

// Load the file helper and write the file to your server

$this->load->helper('file');write_file('/path/to/mybackup.gz', $backup);

// Load the download helper and send the file to your desktop

$this->load->helper('download');force_download('mybackup.gz', $backup);

设置备份首选项

通过向backup()方法的第一个参数提交值数组来设置备份首选项。例:

$prefs = array(        'tables'        => array('table1', 'table2'),   // Array of tables to backup.        'ignore'        => array(),                     // List of tables to omit from the backup        'format'        => 'txt',                       // gzip, zip, txt        'filename'      => 'mybackup.sql',              // File name - NEEDED ONLY WITH ZIP FILES        'add_drop'      => TRUE,                        // Whether to add DROP TABLE statements to backup file        'add_insert'    => TRUE,                        // Whether to add INSERT data to backup file        'newline'       => "\n"                         // Newline character used in backup file);$this->dbutil->backup($prefs);

备份首选项说明

偏爱默认值选项描述表空阵列没有您想要备份的一系列表格。如果留空,所有表格将被导出。

忽视空阵列没有您希望备份例程忽略的一系列表。

格式gzip的gzip,zip,txt导出文件的文件格式。

文件名当前日期/时间没有备份文件的名称。只有在使用zip压缩时才需要该名称。

add_drop真正真假是否在您的SQL导出文件中包含DROP TABLE语句。

add_insert真正真假是否在SQL导出文件中包含INSERT语句。

新队“\ n”“\ n”,“\ r”,“\ r \ n”在SQL导出文件中使用的换行符类型。

FOREIGN_KEY_CHECKS真正真假输出是否应该保持启用外键检查。

类参考

class CI_DB_utilitybackup([$params = array()])

参数:$ params(array) - 一个关联的选项数组返回:原始/(g)压缩的SQL查询字符串

返回类型:串

$ params(array) - 一个关联的选项数组

返回:raw /(g)压缩的SQL查询字符串

返回类型:字符串

根据用户首选项执行数据库备份。

database_exists($database_name)

参数:$ database_name(字符串) - 数据库名称返回:如果数据库存在,则为TRUE,否则为FALSE

返回类型:布尔

$ database_name(字符串) - 数据库名称

返回:如果数据库存在,则返回TRUE;否则返回FALSE

返回类型:布尔值

检查数据库的存在。

list_databases()

返回:找到数据库名称数组返回类型:排列

optimize_database()

返回:优化消息数组或失败时为FALSE返回类型:排列

optimize_table($table_name)

参数:$ table_name(string) - 要优化的表的名称返回:优化消息数组或失败时为FALSE

返回类型:排列

$ table_name(string) - 要优化的表的名称

返回:优化消息数组或失败时为FALSE

返回类型:数组

优化数据库表。

repair_table($table_name)

参数:$ table_name(string) - 要修复的表的名称返回:修复消息数组或失败时为FALSE

返回类型:排列

$ table_name(string) - 要修复的表的名称

返回:修复消息数组或失败时为FALSE

返回类型:数组

修复数据库表。

csv_from_result($query[, $delim = ', '[, $newline = "n"[, $enclosure = '"']]])

参数:$ query(object) - 数据库结果对象$ delim(string) - 要使用的CSV字段分隔符$ newline(string) - 要使用的换行符$ enclosure(string) - 要使用的存储区定界符返回:生成的CSV文件作为字符串

返回类型:串

$ query(object) - 一个数据库结果对象

$ delim(string) - 要使用的CSV字段分隔符

$ newline(string) - 要使用的换行符

$ enclosure(string) - 要使用的机箱分隔符

返回:生成的CSV文件作为字符串

返回类型:字符串

将数据库结果对象转换为CSV文档。

xml_from_result($query[, $params = array()])

参数:$ query(object) - 一个数据库结果对象$ params(array) - 一个首选项的关联数组返回:生成的XML文档作为字符串

返回类型:串

$ query(object) - 一个数据库结果对象

$ params(array) - 一个首选项的关联数组

返回:生成的XML文档作为字符串

返回类型:字符串

将数据库结果对象转换为XML文档。

你可能感兴趣的:(php,utility框架)