Oracle序列 与 基本函数介绍
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序列 与 基本函数介绍的更多相关文章
- oracle 序列介绍
序列介绍 序列是一个计数器,它并不会与特定的表关联.通过创建Oracle序列和触发器实现表的主键自增. 序列的用途一般用来填充主键和计数. 序列使用 1.创建序列 ORACLE序列的语法格式为: CR ...
- Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍
引用自 :http://www.2cto.com/database/201307/224836.html Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍 先假设有这么一个表 ...
- oracle序列在insert into 语句中的使用
很多人创建了序列,但是在插入语句中不知道怎么使用,在此做个简单介绍. oracle序列有两个参数:nextval和currval,使用的时候,需要输入sequence_name.nextval或seq ...
- oracle 序列中cache 有什么用途
create sequence name increment by x //x为增长间隔 start with x //x为初始值 maxvalue x //x为最大值 minvalue x //x为 ...
- Oracle Merge into 详细介绍
Oracle Merge into 详细介绍 /*Merge into 详细介绍MERGE语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句.通过MERGE语句,根据一张表或子查 ...
- oracle序列
一.序列 序列是oracle用来生产一组等间隔的数值.序列是递增,而且连续的.oracle主键没有自增类型,所以一般使用序列产生的值作为某张表的主键,实现主键自增.序列的编号不是在插入记录的时候自动生 ...
- oracle 序列 详解
序列: 是oacle提供的用于产生一系列唯一数字的数据库对象. l 自动提供唯一的数值 l 共享对象 l 主要用于提供主键值 l 将序列值装入内存可以提高访问效率 创建序列: 1. 要有创建 ...
- 触发器 'SA.U_USER_INFO_TRG' 无效且未通过重新验证--Oracle序列
程序开发时报错:触发器 'SA.U_USER_INFO_TRG' 无效且未通过重新验证打开触发器的定义,执行其中的语句,发现序列 U_USER_INFO_SEQ 未定义.什么是序列呢?序列相当于sql ...
- Oracle序列使用:建立、删除
转自:http://www.cnblogs.com/WangPB/archive/2010/07/13/1776766.html 在开始讲解Oracle序列使用方法之前,先加一点关于Oracle cl ...
随机推荐
- Delphi-RzDbgrid-绘制表格式设置某行颜色或者其他格式-以及隔行换色的属性
参考文章:https://www.cnblogs.com/OSKnown/p/8568740.html 在DbgridEh和原生的Dbgrid直接在DrawColumnCell事件中写重绘代码就好了, ...
- 【Bug】MQ消息与事务提交
项目联调期间,遇到个bug,涉及MQ消息传递和事务提交时间问题,简单记录下. 背景 审核服务(审核创建项目),点击审核通过,后台代码会在提交事务前发送MQ消息(该消息由项目管理服务消费),发送成功后, ...
- requests-html模块(下)
render方法 我们先理一下关系requests和的作者是同一个人,pyppeteer是nodejs中puppeteer的非官方实现 requests-html调用的pyppeteer与浏览器进行交 ...
- 分配swap分区空间
1. 分区,并修改为swap分区ID [root@centos2 ~]# fdisk /dev/sdb 欢迎使用 fdisk (util-linux ). 更改将停留在内存中,直到您决定将更改写入磁盘 ...
- 【HICP Gauss】数据库 升级迁移维护-2
DM-Data Manager 集群管理web工具 数据库升级 1.检查版本 依次升级.升级前全备数据 2.磁盘空间不小于表预留空间 3. 确保数据库对包有一定权限 4.升级后正常启停 python ...
- (Linux基础学习)第一章:科普和Linux系统安装
第一章:科普和Linux系统安装 第1节:操作系统介绍OS:Operating System,通用目的的软件程序硬件驱动进程管理内存管理网络管理安全管理文件管理OS分类:服务器OS:RHEL,Cent ...
- 高并发架构系列:Redis并发竞争key的解决方案详解
https://blog.csdn.net/ChenRui_yz/article/details/85096418 https://blog.csdn.net/ChenRui_yz/article/l ...
- 使用navicat创建数据库
1. 打开navicat 2. 选中数据库连接“root”右键->新建数据库 3. 填写数据库名称,注意名称不要以数字开头,不要有中文.空格.特殊字符等 4. 选择“字符集”,常用的为utf ...
- keras模块学习之Sequential模型学习笔记
本笔记由博客园-圆柱模板 博主整理笔记发布,转载需注明,谢谢合作! Sequential是多个网络层的线性堆叠 可以通过向Sequential模型传递一个layer的list来构造该模型: from ...
- PAT乙级1045 快速排序
1045 快速排序 (25分) 著名的快速排序算法里有一个经典的划分过程:我们通常采用某种方法取一个元素作为主元,通过交换,把比主元小的元素放到它的左边,比主元大的元素放到它的右边. 给定划分后的 ...