($width) AND $width .= 'px';
$style = " style=\"width: $width\"";
}
$value = $value ? $value : date('H:i');
$s = "";
return $s;
}
// form_date('start', '2018-07-05') 为空则当前日期
function form_date($name, $value = 0, $width = FALSE)
{
$style = '';
if (FALSE !== $width) {
is_numeric($width) AND $width .= 'px';
$style = " style=\"width: $width\"";
}
$value = $value ? $value : date('Y-m-d');
$s = "";
return $s;
}
/**用法
*
* echo form_radio_yes_no('radio1', 0);
* echo form_checkbox('aaa', array('无', '有'), 0);
*
* echo form_radio_yes_no('aaa', 0);
* echo form_radio('aaa', array('无', '有'), 0);
* echo form_radio('aaa', array('a'=>'aaa', 'b'=>'bbb', 'c'=>'ccc', ), 'b');
*
* echo form_select('aaa', array('a'=>'aaa', 'b'=>'bbb', 'c'=>'ccc', ), 'a');
*/
?>组保留的标签 余下为需要删除的标签
unset($oldtag[$key]);
}
}
}
if (!empty($oldtag)) {
$tagids = array();
foreach ($oldtag as $tagid => $tagname) {
$tagids[] = $tagid;
}
well_oldtag_delete($tagids, $tid);
}
$r = well_tag_process($tid, $fid, $create_tag, $tagarr);
return $r;
}
// 删除标签和绑定的主题
function well_oldtag_delete($tagids, $tid)
{
$pagesize = count($tagids);
$arrlist = well_tag_find_by_tagids($tagids, 1, $pagesize);
$delete_tagids = array(); // 删除
$tagids = array();
$n = 0;
foreach ($arrlist as $val) {
++$n;
if (1 == $val['count']) {
// 只有一个主题
$delete_tagids[] = $val['tagid'];
} else {
$tagids[] = $val['tagid'];
}
}
!empty($delete_tagids) and well_tag_delete($delete_tagids);
$arlist = well_tag_thread_find_by_tid($tid, 1, $n);
if ($arlist) {
$ids = array();
foreach ($arlist as $val) $ids[] = $val['id'];
well_tag_thread_delete($ids);
}
!empty($tagids) and well_tag_update($tagids, array('count-' => 1));
}
// 标签数据处理 $arr=新提交的数组 $tagarr=保留的旧标签
function well_tag_process($tid, $fid, $new_tags = array(), $tagarr = array())
{
if (empty($tid)) return '';
// 新标签处理入库
if ($new_tags) {
$threadarr = array();
$tagids = array();
$i = 0;
$size = 5;
$n = count($tagarr);
$n = $n > $size ? $size : $size - $n;
foreach ($new_tags as $name) {
++$i;
$name = trim($name);
$name = stripslashes($name);
$name = strip_tags($name);
$name = str_replace(array(' ', '#', "@", "$", "%", "^", '&', '·', '<', '>', ';', '`', '~', '!', '¥', '……', ';', '?', '?', '-', '—', '_', '=', '+', '.', '{', '}', '|', ':', ':', '、', '/', '。', '[', ']', '【', '】', '‘', ' ', ' ', ' ', ' ', ' '), '', $name);
$name = htmlspecialchars($name, ENT_QUOTES);
if ($name && $i <= $n) {
// 查询标签
$read = well_tag_read_name($name);
if ($read) {
// 存在 count+1
$tagids[] = $read['tagid'];
} else {
// 入库
$arr = array('name' => $name, 'count' => 1);
$tagid = well_tag_create($arr);
FALSE === $tagid and message(-1, lang('create_failed'));
$read = array('tagid' => $tagid, 'name' => $name);
}
$tag_thread = array('tagid' => $read['tagid'], 'tid' => $tid);
$threadarr[] = $tag_thread;
$tagarr[$read['tagid']] = $read['name'];
}
}
!empty($threadarr) and tag_thread_big_insert($threadarr);
!empty($tagids) and well_tag_update($tagids, array('count+' => 1));
}
$json = empty($tagarr) ? '' : xn_json_encode($tagarr);
return $json;
}
?>return $r;
}
/**
* @param int $page 页数
* @param int $pagesize 每页显示数量
* @return mixed
*/
function link_find($page = 1, $pagesize = 100)
{
$arr = link__find($cond = array(), array('rank' => -1), $page, $pagesize);
return $arr;
}
/**
* @param $id
* @return bool 返回FALSE失败 TRUE成功
*/
function link_delete($id)
{
if (empty($id)) return FALSE;
$r = link__delete(array('id' => $id));
link_delete_cache();
return $r;
}
//--------------------------kv + cache--------------------------
/**
* @return mixed 返回全部友情链接
*/
function link_get($page = 1, $pagesize = 100)
{
$g_link = website_get('friends_link');
if (empty($g_link)) {
$g_link = link_find($page, $pagesize);
$g_link AND website_set('friends_link', $g_link);
}
return $g_link;
}
// delete kv and cache
function link_delete_cache()
{
website_set('friends_link', '');
return TRUE;
}
?> $v = implode(",", $v);
$temp[] = $v;
}
// 去掉重复的字符串,也就是重复的一维数组
$temp = array_unique($temp);
// 再将拆开的数组重新组装
$output = array();
foreach ($temp as $k => $v) {
if ($stkeep) $k = $starr[$k];
if ($ndformat) {
$temparr = explode(",", $v);
foreach ($temparr as $ndkey => $ndval) $output[$k][$ndarr[$ndkey]] = $ndval;
} else $output[$k] = explode(",", $v);
}
return $output;
}
// 合并二维数组 如重复 值以第一个数组值为准
function array2_merge($array1, $array2, $key = '')
{
if (empty($array1) || empty($array2)) return NULL;
$arr = array();
foreach ($array1 as $k => $v) {
isset($v[$key]) ? $arr[$v[$key]] = array_merge($v, $array2[$k]) : $arr[] = array_merge($v, $array2[$k]);
}
return $arr;
}
/*
* 对二维数组排序 两个数组必须有一个相同的键值
* $array1 需要排序数组
* $array2 按照该数组key排序
* */
function array2_sort_key($array1, $array2, $key = '')
{
if (empty($array1) || empty($array2)) return NULL;
$arr = array();
foreach ($array2 as $k => $v) {
if (isset($v[$key]) && $v[$key] == $array1[$v[$key]][$key]) {
$arr[$v[$key]] = $array1[$v[$key]];
} else {
$arr[] = $v;
}
}
return $arr;
}
?>
重装系统后Oracle数据库恢复的方法-软件玩家 - 软件改变生活!
重装系统后Oracle数据库恢复的方法
- 方法(一)
- 2、oradata目录的datafile,tempfile,logfile
-
在开发机器上经常会遇到重装系统的问题,重装之前如果ORACLE没有及时备份的话重装之后就纠结了,数据还原很头疼。各种娘中只能找到一些ORACLE安装与重装系统前目录相同的解决办法,目录不同就没招了。我用的是oracle11G。老版的应该相似。经过我的尝试,找到了几个关键点,现在分享出来。
方法(一)
- 关闭数据库
win + R 输入 sql plus \nolog
SQL> conn / as sysdba
已连接
SQL> shutdown immediate;
数据库已经关闭。
已经卸载数据库。
ORACLE 例程已经关闭。
-
- 手动关闭oracle所有服务
复制旧的Oracle整个目录 D:\app\ 到 D:\app_old\ (重装系统或重装数据库之前操作)
新安装的Oracle整个目录备份 D:\app\ 到 D:\app_new\ (安全起见)
-
覆盖
将D:\app_old\administrator目录下的admin、cfgtoollogs、diag、flash_recover_area、oradata 覆盖到D:\app\administrator下。
-
控制文件CONTROL01.CTL
oracle数据库的控件文件有两个,一个是在oradata\orcl中,名称为CONTROL01.CTL
另外一个是在flash_recovery_area\orcl,名称为CONTROL01.CTL
控制文件也可能是CONTROL02.CTL 或CONTROL03.CTL
2、oradata目录的datafile,tempfile,logfile
原数据库中的文件路径如果和重装后的路径不一致(重装之后分区没变,但是盘符D盘变成了E盘,有其他东西又不方便改,就只能用D了,所以需要改一下数据文件的路径),将这些路径全部修改之后就可以了,具体步骤如下:
- 启动各项oracle服务
- 用sqlplus /nolog命令进入oracle命令符
- 用connect sys/change_on_install as sysdba;命令获得系统管理权限并登录。
- 用select instance_name from v$instance;确认当前的数据库实例是否正确,如果不是oradb需要使用 set oracle_sid来修改默认的oracle实例。
- 将D:\app\administrator\oradata\orcl\CONTROL02.CTL控制文件复制到D:\app\administrator\flash_recovery_area\orcl中,替换目录中原有的控制文件,注意:名称不一样的话改一下名字。
- 使用startup nomount用无装载模式启动数据库。
- 设置数据库为装载模式:alter database mount;
- 查看数据文件清单:select name from v$datafile;
会看到如下结果:
E:\APP\Administrator\ORADATA\ORADB\SYSTEM01.DBF
E:\APP\Administrator\ORADATA\ORADB\SYSAUX01.DBF
E:\APP\Administrator\ORADATA\ORADB\UNDOTBS01.DBF
E:\APP\Administrator\ORADATA\ORADB\USERS01.DBF
E:\APP\Administrator\ORADATA\ORADB\SDMS_DATA01.DBF
SQL> alter database rename file 'E:\app\Administrator\oradata\orcl\SYSTEM01.DBF' to 'D:\app\Administrator\oradata\orclSYSTEM01.DBF' ;
- 查看临时文件清单:select name from v$tempfile;
SQL> alter database rename file 'E:\app\Administrator\oradata\orcl\TEMP01.DBF' to 'D:\app\Administrator\oradata\orcl\TEMP01.DBF' ;
- 查看日志文件清单:select * from v
l
o
g
f
i
l
e
;
s
e
l
e
c
t
∗
f
r
o
m
v
logfile; select * from v
logfile;select∗fromvlogfile;
SQL> alter database rename file 'E:\app\Administrator\oradata\orcl\REDO03.LOG' to'D:\app\Administrator\oradata\orcl\REDO03.LOG';
- 启动数据库:alter database open;
SQL> alter database open;
好了,现在可以用客户端连接这个数据库了。
关于控制文件错误导致的问题
控制文件的错误,请检查警报日志中获得更多信息
通过:/app/administrator/diag/rdbms/ora11g/ora11g/alert/log.xml文件中找出实例启动日志
参考资料:
https://wwwblogs/cnsend/p/13783104.html
https://wwwblogs/sparkbj/articles/6146247.html
本文标签:
重装系统数据库方法Oracle
更多相关文章
登录QQ微信顺利,打开网页却卡壳了?答案在这儿等你!
又碰到这个垃圾问题。。。来给自己MARK一下! 方法1. 修改DNS地址 这是网上常见的修改步骤,可以查到很多教程。打开网络中心打开 Internet 协议版本 4 (TCPIPV4
电脑换了新硬盘,还需要重新安装系统吗?别急,这里有答案!
电脑硬盘是电脑的核心组成硬件之一,主要是用来安装操作系统的硬件,如果电脑系统盘硬盘坏了的话电脑就无法进行系统使用了。那么如果电脑换硬盘要重装系统吗?下面小编就给大家分析下电脑换硬盘是否要重装系统。 一、电脑换硬盘要重装系统的情
想要甩掉Word页眉的横线?这个方法你一定不能错过!
01如何给Word添加页眉?方法1:打开Word文档,将鼠标放在Word顶部,双击鼠标,就可以进入页眉编辑状态,这时候,直接添加页眉内容就好了。方法2:在Word文档顶部菜
删掉Word页眉横线不再神秘,简单几步快速实现!
Word页眉横线删除全攻略:5种实用方法详解 在日常办公中,Word文档的页眉横线常常成为困扰用户的细节问题。这条看似简单的横线,在正式文档中可能影响排版美观,在简历或合同中更可能破坏整体专业性。本文将系统梳理5种高效解决方案
别再被卡在加载环了,掌握这些方法,让你玩转网页上的SWF和Flash视频
终极视频下载解决方案:轻松保存网页视频的完整指南 还在为无法保存心爱的视频内容而烦恼吗?每次看到精彩的在线课程、有趣的短视频或重要的工作素材,却只能眼睁睁看着它们在刷新后消失?今天,我将向您展示一款真正能够解决这一痛点的工具—
XLIVE.DLL加载失败?教你三招轻松搞定,让闪退问题不再困扰你!
电脑使用中,动态链接库(DLL)文件加载失败是一个常见的技术障碍,并且特别提到的xlive.dll加载问题尤其普遍。xlive.dll是微软公司推出的“Games for Windows - LIVE”服务所依赖的核心DLL文件,这对
告别复杂教程!简单四步,实现一键系统安装
电脑系统变得越来越卡,使用不流畅想要更换系统怎么办?这个时候我们可以给电脑重装系统。重装系统的方法,那么怎样装系统方便快捷呢?其实我们可以借助工具实现快速安装系统的目的,下面是一个傻瓜式的一键安装系统软件使用方法。可以利用小白一键重装
Word用户必看:一步到位删除多余空白页的实用技巧大全!
平时使用Word写文档时,经常遇到在编辑处理完文档后会发现Word中多出了一个或多个空白页,而这些空白页上已经没有任何内容却怎么都删不了,很是苦恼。 本文主要讲解了5种经过小编测试有效的删除Word文档中空白页的方法。其中
Adobe Flash Center大难题?轻松搞定无法开启的SWF文件
Word文档打不开?四招轻松解决在日常办公中,Word文档作为不可或缺的工具,承载着大量的文字处理和文档编辑工作。然而,当用户急于查看或编辑某个Word文档时,却发现它无法打开,这无疑会让人倍感焦虑。这种情况不仅会导致时
一招制胜!用注册表技巧封死IE浏览器的主页
也许有人遇到过,打开IE浏览器发现不是自己设置的主页,于是就去改主页设置,可以无论怎么修改都不行,让人头疼发蒙。这是因为一些恶意软件或木马在注册表中修改了主页的设置,导致无法使用常规的设置修改主页。今天和大家分享下如何使用注册表来锁定
电脑上装不上游戏?试试这个解决xinput1_3.dll的指南!
当电脑出现提示,显示 xinput1_3.dll文件缺失时,这实际上是一种常见的DLL文件遗失错误,其修复过程通常相对简单。今天,我们将探讨四种不同的方法来解决 xinput1_3.dll缺失的问题。 一.xinput
找不着msvcp110.dll?别慌,这里有五种简单解决方式!
在现代社会,计算机已经成为我们生活和工作中不可或缺的一部分。然而,随着计算机技术的不断发展,我们也会遇到各种各样的问题。其中,msvcp110.dll丢失是许多用户经常遇到的问题之一。本文将详细介绍msvcp110.dll丢失的修复方
Word里分数不会打?这里有个超实用的输入方法!
你有没有在使用word文档编辑时,遇到需要打出分数或输入特殊符号的难题?如果你也感到无从下手,不知道word怎么打分数,不如就来跟着文章一起学习吧! 我将分享2个快捷有效的技巧,教你如何在Word中轻松打出分数和输入各种特殊符
面对Word文档开不了机的烦恼?看这里找答案!
word文档打不开的常见原因?好的处理方法 最近使用办公软件经常出现打开Word文档没有响应的情况。Word是我们生活办公中常用的软件,会遇到这样的问题是不可避免的。那么遇到 word文档打不开的常见原
在安卓设备上构建你的专属弹幕:视频娱乐新体验
简单概述 现在有个很流行视频的效果就是 弹幕效果,满屏幕的文字从右到左飘来飘去。看的眼花缭乱,看起来还蛮cool的现在就是来实现这一的一个效果,大部分的都是从右向左移动漂移,本文的效果中也支持从左向右的
一键取消电脑开机密码,轻松恢复使用
电脑开机密码是保护个人隐私和计算机安全的重要手段,但有时用户可能希望取消这个设置以提高使用便捷性。本文将介绍三种电脑怎么取消开机密码的方法,适用于不同品牌不同类型的电脑,为用户提供更灵活的操作选择。 方法1:使用系统设置取消密
告别内存不能读取:轻松搞定Flash Player的故障
内存不能为read正确修复方法2010年06月03日内存不能为read正确修复方法:内存指令不能read,这是在电脑使用中常常出现地情况,内存是主板上地存储部件,是CPU直接与之沟通,并用其寄存当前正在使用地(即
轻松学会RAR压缩包加密:三种方法,保护你的文件秘密
文件压缩成rar压缩包后,想要保护文件内容不被他人随意解压,我们可以给rar压缩包设置加密,今天分享3种方法设置rar文件加密方法。 方法一:加密 最简单的加密方法,就是在加密文件时输入想要设置的密码,完成加密和压缩了
一步到位,教你解锁系统隐藏文件的正确姿势!
一、问题背景 有时候急着找一份重要文件,明明记得存在电脑里, 翻遍所有文件夹却连影子都看不到!是不是瞬间慌了神, 怀疑文件被误删,甚至担心电脑中病毒了? 其实不用瞎着急!
“一招搞定:让你的隐藏文件不再神秘”
一、问题背景 有时候急着找一份重要文件,明明记得存在电脑里, 翻遍所有文件夹却连影子都看不到!是不是瞬间慌了神, 怀疑文件被误删,甚至担心电脑中病毒了? 其实不用瞎着急!
发表评论