database.php
来自「全新且完善的强大网上商店系统」· PHP 代码 · 共 202 行
PHP
202 行
<?php
function osc_db_connect($server, $username, $password, $link = 'db_link') {
global $$link, $db_error;
$db_error = false;
if (!$server) {
$db_error = 'No Server selected.';
return false;
}
$$link = @mysql_connect($server, $username, $password) or $db_error = mysql_error();
return $$link;
}
function osc_db_select_db($database) {
return mysql_select_db($database);
}
function osc_db_close($link = 'db_link') {
global $$link;
return mysql_close($$link);
}
function osc_db_query($query, $link = 'db_link') {
global $$link;
return mysql_query($query, $$link);
}
function osc_db_fetch_array($db_query) {
return mysql_fetch_array($db_query);
}
function osc_db_num_rows($db_query) {
return mysql_num_rows($db_query);
}
function osc_db_data_seek($db_query, $row_number) {
return mysql_data_seek($db_query, $row_number);
}
function osc_db_insert_id() {
return mysql_insert_id();
}
function osc_db_free_result($db_query) {
return mysql_free_result($db_query);
}
function osc_db_test_create_db_permission($database) {
global $db_error;
$db_created = false;
$db_error = false;
if (!$database) {
$db_error = 'No Database selected.';
return false;
}
if (!$db_error) {
if (!@osc_db_select_db($database)) {
$db_created = true;
if (!@osc_db_query('create database ' . $database)) {
$db_error = mysql_error();
}
} else {
$db_error = mysql_error();
}
if (!$db_error) {
if (@osc_db_select_db($database)) {
if (@osc_db_query('create table temp ( temp_id int(5) )')) {
if (@osc_db_query('drop table temp')) {
if ($db_created) {
if (@osc_db_query('drop database ' . $database)) {
} else {
$db_error = mysql_error();
}
}
} else {
$db_error = mysql_error();
}
} else {
$db_error = mysql_error();
}
} else {
$db_error = mysql_error();
}
}
}
if ($db_error) {
return false;
} else {
return true;
}
}
function osc_db_test_connection($database) {
global $db_error;
$db_error = false;
if (!$db_error) {
if (!@osc_db_select_db($database)) {
$db_error = mysql_error();
} else {
if (!@osc_db_query('select count(*) from bsp_configuration')) {
$db_error = mysql_error();
}
}
}
if ($db_error) {
return false;
} else {
return true;
}
}
function osc_db_install($database, $sql_file) {
global $db_error;
$db_error = false;
if (!@osc_db_select_db($database)) {
if (@osc_db_query('create database ' . $database)) {
osc_db_select_db($database);
} else {
$db_error = mysql_error();
}
}
if (!$db_error) {
if (file_exists($sql_file)) {
$fd = fopen($sql_file, 'rb');
$restore_query = fread($fd, filesize($sql_file));
fclose($fd);
} else {
$db_error = 'SQL file does not exist: ' . $sql_file;
return false;
}
$sql_array = array();
$sql_length = strlen($restore_query);
$pos = strpos($restore_query, ';');
for ($i=$pos; $i<$sql_length; $i++) {
if ($restore_query[0] == '#') {
$restore_query = ltrim(substr($restore_query, strpos($restore_query, "\n")));
$sql_length = strlen($restore_query);
$i = strpos($restore_query, ';')-1;
continue;
}
if ($restore_query[($i+1)] == "\n") {
for ($j=($i+2); $j<$sql_length; $j++) {
if (trim($restore_query[$j]) != '') {
$next = substr($restore_query, $j, 6);
if ($next[0] == '#') {
for ($k=$j; $k<$sql_length; $k++) {
if ($restore_query[$k] == "\n") break;
}
$query = substr($restore_query, 0, $i+1);
$restore_query = substr($restore_query, $k);
// join the query before the comment appeared, with the rest of the dump
$restore_query = $query . $restore_query;
$sql_length = strlen($restore_query);
$i = strpos($restore_query, ';')-1;
continue 2;
}
break;
}
}
if ($next == '') { // get the last insert query
$next = 'insert';
}
if ( (eregi('create', $next)) || (eregi('insert', $next)) || (eregi('drop t', $next)) ) {
$next = '';
$sql_array[] = substr($restore_query, 0, $i);
$restore_query = ltrim(substr($restore_query, $i+1));
$sql_length = strlen($restore_query);
$i = strpos($restore_query, ';')-1;
}
}
}
osc_db_query("drop table if exists bsp_address_book, bsp_categories, bsp_categories_description, bsp_configuration, bsp_configuration_group, bsp_countries, bsp_currencies, bsp_customers, bsp_customers_basket, bsp_customers_basket_attributes, bsp_languages, bsp_manufacturers, bsp_manufacturers_info, bsp_orders,bsp_orders_products, bsp_orders_status, bsp_orders_status_history, bsp_orders_products_attributes, bsp_orders_products_download, bsp_products, bsp_products_attributes, bsp_products_attributes_download, bsp_prodcts_description, bsp_products_options, bsp_products_options_values, bsp_products_options_values_to_products_options,bsp_products_to_categories, bsp_reviews, bsp_reviews_description, bsp_sessions, bsp_specials, bsp_tax_class, bsp_tax_rates, bsp_geo_zones, bsp_whos_online, bsp_zones, bsp_zones_to_geo_zones, bsp_styles,bsp_stylevars
,bsp_templates, bsp_usergroups");
for ($i=0; $i<sizeof($sql_array); $i++) {
osc_db_query($sql_array[$i]);
}
} else {
return false;
}
}
?>
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?