Oracle or Question Solve(一)
Oracle查看版本命令:select * from v$version;
ORACLE_BASE和ORACLE_HOME路径查看
su - oracle
echo $ORACLE_BASE
echo $ORACLE_HOME
SGA参数查看:
sqlplus / as sysdba
show parameter sga
sga_max_size的值写上就好
process参数查看:
sqlplus / as sysdba
show parameter process
是否开启归档:
sqlplus / as sysdba
archive log list
SQL> archive log list
Database log mode Archive Mode
Automatic archival Enabled
Archive destination USE_DB_RECOVERY_FILE_DEST
Oldest online log sequence 26
Next log sequence to archive 28
Current log sequence 28
Enable既是开启归档的
是否语句空表导出(必改):
show parameter seg
出来是false即算开启,说明空表可以导出
是否密码180天密码过期(必改):
select * from dba_profiles where profile='DEFAULT' and resource_name='PASSWORD_LIFE_TIME';
Unlimited说明密码永不过期
是否关闭密码大小写敏感(必改):
show parameter logon
出来是FALSE即可,说明密码不区分大小写
是否关闭审计:
show parameter audit
如果出来结果是NONE,证明关闭审计了,这样就可以尽可能的避免SYSTEM爆满
查看datafile路径
Select name from v$datafile
SQL> select name from v$datafile;
NAME
---------------------------------------------
/u01/oracle/oradata/system05.dbf
在Linux下exp的时候,记得先查看echo $NLS_LANG
如果不是ZHS16GBK,那样导出的会造成dmp导入时乱码的,
可以调整oracle用户的环境变量,
vi ~/.bash_profile 在文件里面添加一句export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK
然后要生效,
可以重新切换用户到oracle,或者source ~/.bash_profile
Rman路径:
su - oracle
crontab -l
可以看到计划任务里面有个备份脚本,
0 0 * * * /u01/rmanbak/rmanbak.sh>/u01/rmanbak/rmanbak.log2>&1
查看备份脚本,
cat /databak/rmanbak/rmanbak.sh
#!/bin/bash
.~/.bash_profile
echo---------------------start---------------------------;date
rman target/<<EOF
backup as compressed backupset database include current controlfile format
‘/u01/rman/rmanbak/full_%U.bak’;
Delete noprompt obsolete;
exit;
EOF
Echo--------------------------end------------------------------;date
这个就是rman备份路径 /u01/rman/rmanbak
数据库硬盘不够 是可以删除 trace 下文件
参考 rm -f *.trc
rm -rf *.trm
du -sh *
pwd
/u01/oracle/diag/rdbms/orcl/orcl
oracle数据库迁移常用函数
wm_concat()函数,系统自己添加的一个分组聚合函数,作用是把一个字段的多个值合并在一起显示,并用‘,’作为分割符
例1 不分组,取合并后的结果
select wm_concat(a) from (
select '123' a,'1' n from dual
union all
select '456' a,'2' n from dual
union all
select '789' a,'3' n from dual
union all
select '10' a,'1' n from dual
)
WM_CONCAT(A)
123,456,789,10
例2:按条件分组后,取每一组的合并后的结果
select wm_concat(a),n from (
select '123' a,'1' n from dual
union all
select '456' a,'2' n from dual
union all
select '789' a,'3' n from dual
union all
select '10' a,'1' n from dual
)group by n;
WM_CONCAT(A) N
123,10 1
456 2
789 3
lengthb()函数,按字节数统计长度,区别于length()按字符数统计长度
例子:
select length('123') ,lengthb('123'),length('123字'),lengthb('123字') from dual ;
LENGTH('123') LENGTHB('123') LENGTH('123字') LENGTHB('123字')
3 3 4 5
----decode(); 类似case when ,decode()函数参数可以随意增加
---具体的实现是decode(a,b,c,d)如果a =b,则结果为c,不然结果为d,
---当参数是decode(a,b,c,d,e,f),如果a =b,则结果为c,如果a<>b,则a和d比,如果a=d ,则结果为e,不然结果为f
---不同的参数个数,依次类推,可自己尝试
--例子:
select decode('aaaaa','123','1','aaa','2','aaaaa','3','4') from dual ;
结果为 3
---substr() substr()是截取函数,主要有三个参数,字符串,起始位置,长度,需要注意的是,
起始长度从1开始计数,且不管起始位置是不是负数,函数都是从左往右截取,
--如果起始位置为负数,其意思是从右往左的位数
--例子:
select substr('12345678',1,5),substr('12345678',-4,3) from dual ;
SUBSTR('12345678',1,5) SUBSTR('12345678',-4,3)
12345 567
---instr() instr(str_a,str_b,int_a,int_b)函数主要是查找该字符串str_a中,str_b字符或字符串,从下标第int_a位置开始,第int_b次出现的下标
--例子:
select instr('abcdefabcdef','ab',1,1) ,instr('abcdefabcdef','ab',1,2),instr('abcdefabcdef','ab',3,1) from dual ;
INSTR('ABCDEFABCDEF','AB',1,1) INSTR('ABCDEFABCDEF','AB',1,2) INSTR('ABCDEFABCDEF','AB',3,1)
1 7 7
---可以尝试将substr() 和instr() 结合,具体自己操作
----insert
--插入的时候碰到违反唯一的处理方法
insert into tab_a select * from tab_b
--1.查看违反唯一原因是不是因为已经在a表中存在b表的部分数据,语句如下:
select * from tab_a a where exists (select 'x' from tab_b b where a.key1=b.key1 and ... );
--2.查看违反唯一原因是不是将tab_b表中,对应tab_a表主键的字段有重复数据,先查看tab_a的主键字段,在看在tab_b中是否有重复数据
select key1,key2... from tab_b group by key1,key2... having count(*)>1;
备注:随笔中内容来源于网上资料整理,仅供参考。
Oracle or Question Solve(一)的更多相关文章
- Oracle or Question Solve(二)
数据库常用语句和函数 ----update update()函数主要注意的是后面的where限制条件--例子:update tab_a a set a.v1 = (select b.v1 from t ...
- 一篇分析诊断被"hang"住数据库的资料(Oracle Performance Diagnostic Guide——Hang/Locking)
该资料已上传至本人QQ群空间,如需该资料,可到本人QQ群空间查找.下面贴表文本: Oracle Performance Diagnostic GuideHang/LockingVersion 3.1. ...
- 12 Things Developers Will Love About Oracle Database 12c Release 2
by Chris Saxon-Oracle It's Here: Oracle Database 12c Release 2 (12.2) Is available on Oracle Cloud. ...
- Oracle中的commit详解
本文转自 : http://blog.csdn.net/hzhsan/article/details/9719307 它执行的时候,你不会有什么感觉.commit在数据库编程的时候很常用,当你执行DM ...
- oracle常用的快捷键
最近在开发过程中,遇到一些麻烦,就是开发效率问题,有时候其他同事使用PLSQL 编程效率明显高于自己,观察了好久,才发现他使用PLSQL 已经很长时间了而且,他自己也在其中添加了好多快捷方式, 1.登 ...
- ORACLE动态采样分析
td {border:solid #9ec9ec; border-width:0px 1px 1px 0px; padding:4px 0px;} table {border:1px solid #9 ...
- 如何将EXCEL表导入ORACLE数据库中?【转】
来源:https://zhidao.baidu.com/question/383828330.html?qbl=relate_question_2&word=excel%20%B1%ED%CA ...
- rhel5.8安装oracle 10g ASM
1.所有的配置和文件系统一样 2.规划: 加了8块小盘,ASM为了实验使用asmlib驱动(rhel6不再支持asmlib驱动),裸设备的2种方法(rowdevice和udev) 三块盘使用asmli ...
- win7 ins 30131 oracle 12c
Cause - Failed to access the temporary location. Action - Ensure that the current user has required ...
随机推荐
- ES6中set的用法回顾
ES6中的set类似一个数组,但是其中的值都是唯一的,Set本身是一个构造函数,用来生成 Set 数据结构. set函数可以接受一个数组作为参数,用来初始化: const set = new Set( ...
- springboot jpa 级联操作及测试问题 (@Transactional与@Test)
前言:测试springboot版本 :springBootVersion = '2.0.5.RELEASE' 一 :搬运@Transactional B. 如果加了事务,必须做好开发环境测试( ...
- VS2017使用assimp 5.0.0 error C2589: '(' : illegal token on right side of '::' 解决办法
坑爹微软Sucks Again. assimp 终于更新到了5.0.0并且支持GLTF2格式,包含动画正确解析,在viewer中也能看到正确结果,真他喵的不容易,然后拿来编译完到自己项目里用,就出这玩 ...
- mysql内存数据淘汰机制和大查询会不会把内存打爆?
首先我们说一下大查询会不会把内存打爆? 比如说主机内存有5g,但是我们一个大查询的数据有10g,这样会不会把内存打爆呢? 答案:不会 为什么? 因为mysql读取数据是采取边读边发的策略 select ...
- JavaScript高级程序设计(第3版) 第三章 (基本概念)
3.1 语法 1.不以数字开头的数字,字母,下划线,美元符号 2.注释:html <!-- --> css/**/ js单行// 多行/**/ 3.ES5 引入了严格模式(strict m ...
- .net 学习官网
https://docs.microsoft.com
- Linux下查看日志文件
问题一:日志文件打开,卡死 在公司开发的时候,开发的程序在本地测试正常,但是在测试环境却有问题.这个时候第一反应就是查看日志文件,看看日志文件里面有什么错误信息.我潇洒的执行了一下 vim log.t ...
- Codeforces - 1194C - From S To T - 子序列 - 排序
https://codeforces.com/contest/1194/problem/C 好像没什么好说的,要能构造s必须是t的子序列,并且相差的字符集合d是p的子集. 用双指针法求两遍子序列就可以 ...
- python学习三十八天常用内置函数分类汇总
python给我们提供丰富的内置函数,不用去写函数体,直接调用就可以运行,很方便快速给我提供开发所需要的函数. 1,查内存地址 id() 变量的内存地址 id() 2,输入输出 input() pr ...
- tensorflow教程:tf.contrib.rnn.DropoutWrapper
tf.contrib.rnn.DropoutWrapper Defined in tensorflow/python/ops/rnn_cell_impl.py. def __init__(self, ...