Oracle序列 与 基本函数介绍

常用词汇

expire

[ɪkˈspaɪə(r)]

v.

失效,终止;到期;

数据字典(data dictionary:dd)

描述逻辑存储结构和物理存储结构的数据表,还包括描述其他数据对象信息的表:

数据字典名称 说明
dba_tablespaces 关于表空间的信息
dba_ts_quotas 所有用户表空间限额
dba_free_space 所有表空间中的自由分区
dba_segments 描述数据库中所有段的存储空间
dba_extents 数据库中所有分区的信息
dba_tables 数据库中所有数据表的描述
dba_tab_columns 所有表、视图以及簇的列
dba_views 数据库中所有视图的信息
dba_synonyms 关于同义词的信息
dba_sequences 所有用户序列信息
dba_constraints 所有用户表的约束信息
dba_indexs 数据表中所有索引的描述
dba_ind_columns 所有表及簇上压缩索引的列
dba_triggers 所有用户的触发器信息
dba_source 所有用户存储过程信息
dba_data_files 查询关于数据库文件的信息
dba_tab_grants/privs 查询关于对象授权的信息
dba_objects 数据库所有对象
dba_users 关于数据库中所有用户的信息
-- 清空屏幕
clear
clear screen create user tester identified by abc123;
grant connect,resource to tester;
conn tester/abc123@mydog
-- 查询数据库中所有用户的信息
Select * from user_tables;

oracle序列技术理解

sequence(序列,是一个对象,和表是平级的,专门用来做自增)

在高级数据中,自增是一个独立的部件,而不是字段的辅助属性

idenitity,auto_increment

oracle的自增跟普通的数据库的自增不一样,它是通过对象来自增的,这个对象叫序列

oracle数据库有一种表叫user_sequences,专门保存了一种专门用来做自增的部件

查看用户是否有序列存在

select count(*) from user_sequences;

在oracle中,如果不from某张表,是无法进行任何操作的

为了凑足语法,oracle专门准备一张表(dual),一个字段一行记录

-- sysdate是一个日期函数
select sysdate from dual;
conn tester/abc123@mydog

create sequence seq_stu_no;
select count(*) from user_sequences; -- 需要先查询nextval,不然就没有当前值
select seq_stu_no.nextval from dual;
select seq_stu_no.currval from dual; create table tbl_student(
stu_no int primary key,
stu_name varchar2(30) not null
); -- oracle的自增是一个对象,这个对象是序列
insert into tbl_student values(seq_stu_no.nextval,'mary');
insert into tbl_student values(seq_stu_no.nextval,'davud');
insert into tbl_student values(seq_stu_no.nextval,'jenny');
insert into tbl_student values(seq_stu_no.nextval,'mike'); -- 创建用户tester序列
create sequence tester.seq_xyz; select * from user_sequences;
create sequence seq_desk_no
minvalue 1000
maxvalue 2000
increment by 100; select * from user_sequences;
select seq_desk_no.nextval from dual;
select seq_desk_no.currval from dual;
alter sequence seq_desk_no cache 10;
alter sequence seq_desk_no increment by 2;
select seq_desk_no.nextval from dual;
select seq_desk_no.currval from dual;
drop sequence seq_desk_no;

账号管理

用户管理

select * from dba_users;
select * from dba_users order by user_id desc; alter user hr identified by abc123;
conn hr/abc123@mydog
-- 因为账户被锁定,所以无法登录 -- 解锁账户
alter user hr account unlock; conn hr/abc123@mydog conn sys/manager@mydog as sysdba alter user hr account lock;
-- 锁定离职员工账户 conn sys/manager@mydog as sysdba
-- password expire:用来设置用户口令过期,失效,强制用户登录数据库时候必须修改口令
create user tester2 identified by abc123 password expire;
grant connect,resource to tester2;
select * from dba_users; conn tester2/abc123@mydog
-- 然后需要修改密码,验证密码,进入tester2账户 conn scott/tiger@mydog
select table_name from user_tables;
select * from emp;
-- 描述表的结构
desc emp;

基本函数介绍及应用

单行函数(字符函数)

conn scott/tiger@mydog
-- 小写字符转大写
select upper('smith') from dual;
-- 大写字符转小写
select lower('TOM') from dual;
-- 取整函数,四舍五入
select round(4.5) from dual; -- emp是scott用户的专属表
select * from emp where DEPTNO<>'10'; -- 会排除掉DEPTNO所有值是10的行数据 select (sysdate-hiredate)/365 from emp;
select round(sysdate-hiredate)/365 from emp;
select round((sysdate-hiredate)/365) work_years from emp;
select empno,ename,round((sysdate-hiredate)/365) work_years from emp; -- 获取两个时间之间的月份
select months_between(sysdate,hiredate) months from emp; -- 时间转字符串,只转年份
select to_char(hiredate,'yyyy') from emp;
select to_char(hiredate,'yyyy-mm-dd') from emp; select * from emp;
select sal+comm from emp; -- 如果comm列中有空值,则用0来代替
select empno,ename,sal,nvl(comm,0) from emp; -- decode形成if--else语句
select empno,ename,sal,nvl(comm,0),deptno,
decode(deptno,
10,'总部',
20,'销售部',
30,'研发部',
'---') dept from emp; select empno,ename,sal,nvl(comm,0),deptno,
case
when deptno = 10 then '总部'
when deptno = 20 then '销售部'
when deptno = 30 then '研发部'
else
'----'
end
as deptinfo
from emp;

海韵听心

PL/SQL Developer中文字段显示乱码

解决方法

原因:因为数据库的编号格式和pl /sql developer的编码格式不统一造成的。

解决步骤

1、查看oracle数据库字符集:

sql语句:

select userenv('language') from dual;

结果集:

AMERICAN_AMERICA.ZHS16GBK

2、新建环境变量

我的电脑(右键-属性) - 高级系统设置 - 高级 - 环境变量 - 系统变量 - 新建

变量名:NLS_LANG

变量值:与oracle数据库字符集一致

3、重启pl/sql developer

Oracle序列 与 基本函数介绍的更多相关文章

  1. oracle 序列介绍

    序列介绍 序列是一个计数器,它并不会与特定的表关联.通过创建Oracle序列和触发器实现表的主键自增. 序列的用途一般用来填充主键和计数. 序列使用 1.创建序列 ORACLE序列的语法格式为: CR ...

  2. Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍

    引用自 :http://www.2cto.com/database/201307/224836.html   Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍 先假设有这么一个表 ...

  3. oracle序列在insert into 语句中的使用

    很多人创建了序列,但是在插入语句中不知道怎么使用,在此做个简单介绍. oracle序列有两个参数:nextval和currval,使用的时候,需要输入sequence_name.nextval或seq ...

  4. oracle 序列中cache 有什么用途

    create sequence name increment by x //x为增长间隔 start with x //x为初始值 maxvalue x //x为最大值 minvalue x //x为 ...

  5. Oracle Merge into 详细介绍

    Oracle Merge into 详细介绍 /*Merge into 详细介绍MERGE语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句.通过MERGE语句,根据一张表或子查 ...

  6. oracle序列

    一.序列 序列是oracle用来生产一组等间隔的数值.序列是递增,而且连续的.oracle主键没有自增类型,所以一般使用序列产生的值作为某张表的主键,实现主键自增.序列的编号不是在插入记录的时候自动生 ...

  7. oracle 序列 详解

    序列: 是oacle提供的用于产生一系列唯一数字的数据库对象. l  自动提供唯一的数值 l  共享对象 l  主要用于提供主键值 l  将序列值装入内存可以提高访问效率 创建序列: 1.  要有创建 ...

  8. 触发器 'SA.U_USER_INFO_TRG' 无效且未通过重新验证--Oracle序列

    程序开发时报错:触发器 'SA.U_USER_INFO_TRG' 无效且未通过重新验证打开触发器的定义,执行其中的语句,发现序列 U_USER_INFO_SEQ 未定义.什么是序列呢?序列相当于sql ...

  9. Oracle序列使用:建立、删除

    转自:http://www.cnblogs.com/WangPB/archive/2010/07/13/1776766.html 在开始讲解Oracle序列使用方法之前,先加一点关于Oracle cl ...

随机推荐

  1. Gradle3.0新指令api、provided、implementation等对比

    Android Studio3.0正式版已经出来了,相比2.x的版本,Gradle版本也升级为了3.x,编译速度提高了不少. 在gadle3.0之后,默认的依赖由之前的compile更改为implem ...

  2. Air for ANE:一星期的调试笔记

    来源:http://blog.csdn.net/hero82748274/article/details/8656674 第一次尝试ANE的东西,让我感觉到很折腾人.adobe 出的这个方案虽然可以解 ...

  3. "Oracle要对Java收费了,SAP基于Java技术栈的那些产品的客户怎么办"

    今年年初的时候,所谓"Oracle要对Java收费"的新闻,在网上传得沸沸扬扬.这个新闻被专业人士视为标题党,而国内众多技术论坛,比如知乎社区上,有很多大神对"Java收 ...

  4. 2.kafka 分布式集群安装

    Kafka集群安装主节点h201,从节点h202.h2031.安装jdk1.8[hadoop@h201 ~]$ /usr/jdk1.8.0_144/bin/java -version 2.安装zook ...

  5. mysql学习之基础篇08 UTF8编码

    这次我们来说一下在Mysql中的编码问题: 我们知道应用于计算机的最早的字符集是ASCII,它所组成的编码是ASCII编码:由于对于其他国家来说它所容纳的字符个数比较少,后来就出现了ANSI字符集,它 ...

  6. Nginx配置文件示例

    Nginx的配置文件示例:(仅供参考) 强烈建议先将默认的配置文件备份再进行操作! 请根据自己项目的实际路径来配置相关路径! uwsgi配置文件请参考:uwsgi配置文件示例 # For more i ...

  7. Maven简易笔记

    Maven笔记 Maven笔记 Maven组成 安装配置 基本概念 Maven目录的典型结构 POM文件格式 GAV 依赖 依赖管理与父项目 关于父项目的一点主意事项 repository Maven ...

  8. egg 完整实例 增删改查MongoDB,websocket

    项目地址 github.com/richard1015… 技术栈 eggjs.MongoDB.swagger.websocket.Amap 演示地址: 前台 school.zhuzhida.vip A ...

  9. [2019/05/17]解决springboot测试List接口时JSON传参异常

    报错信息,大致如下 c.c.c.c.a.BaseControllerExceptionHandler : 运行时异常: java.lang.IllegalStateException: No prim ...

  10. IBM MQ V6.0 for Windows7

    https://blog.csdn.net/guolf521/article/details/87913141 websphere 商用中间件MQ 轨道交通使用