本文整理汇总了PHP中MDB2_Driver_Common::getUserInfo方法的典型用法代码示例。如果您正苦于以下问题:PHP MDB2_Driver_Common::getUserInfo方法的具体用法?PHP MDB2_Driver_Common::getUserInfo怎么用?PHP MDB2_Driver_Common::getUserInfo使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类MDB2_Driver_Common
的用法示例。
在下文中一共展示了MDB2_Driver_Common::getUserInfo方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: connectMDB2
/**
* connect to the database using mdb2
*/
public static function connectMDB2()
{
if (self::$connection) {
if (self::$backend == self::BACKEND_PDO) {
self::disconnect();
} else {
return true;
}
}
// The global data we need
$name = OC_Config::getValue("dbname", "owncloud");
$host = OC_Config::getValue("dbhost", "");
$user = OC_Config::getValue("dbuser", "");
$pass = OC_Config::getValue("dbpassword", "");
$type = OC_Config::getValue("dbtype", "sqlite");
$SERVERROOT = OC::$SERVERROOT;
$datadir = OC_Config::getValue("datadirectory", "{$SERVERROOT}/data");
// do nothing if the connection already has been established
if (!self::$MDB2) {
// Require MDB2.php (not required in the head of the file so we only load it when needed)
require_once 'MDB2.php';
// Prepare options array
$options = array('portability' => MDB2_PORTABILITY_ALL - MDB2_PORTABILITY_FIX_CASE, 'log_line_break' => '<br>', 'idxname_format' => '%s', 'debug' => true, 'quote_identifier' => true);
// Add the dsn according to the database type
switch ($type) {
case 'sqlite':
case 'sqlite3':
$dsn = array('phptype' => $type, 'database' => "{$datadir}/{$name}.db", 'mode' => '0644');
break;
case 'mysql':
$dsn = array('phptype' => 'mysql', 'username' => $user, 'password' => $pass, 'hostspec' => $host, 'database' => $name);
break;
case 'pgsql':
$dsn = array('phptype' => 'pgsql', 'username' => $user, 'password' => $pass, 'hostspec' => $host, 'database' => $name);
break;
case 'oci':
$dsn = array('phptype' => 'oci8', 'username' => $user, 'password' => $pass, 'charset' => 'AL32UTF8');
if ($host != '') {
$dsn['hostspec'] = $host;
$dsn['database'] = $name;
} else {
// use dbname for hostspec
$dsn['hostspec'] = $name;
$dsn['database'] = $user;
}
break;
default:
return false;
}
// Try to establish connection
self::$MDB2 = MDB2::factory($dsn, $options);
// Die if we could not connect
if (PEAR::isError(self::$MDB2)) {
OC_Log::write('core', self::$MDB2->getUserInfo(), OC_Log::FATAL);
OC_Log::write('core', self::$MDB2->getMessage(), OC_Log::FATAL);
OC_Template::printErrorPage('can not connect to database, using ' . $type . '. (' . self::$MDB2->getUserInfo() . ')');
}
// We always, really always want associative arrays
self::$MDB2->setFetchMode(MDB2_FETCHMODE_ASSOC);
}
// we are done. great!
return true;
}