SQL 序列-DML-DML-数据类型-用户管理、权限-事务-视图
--DML
--insert关键字
--作用:往表中插入一条(多条)记录
--元祖(tuple)值式的插入(一次插入一条记录)
--语法1:insert into tablename(column1,column2,...,columnN) values(val1,val2,...,valN)
--例子:
insert into emp(empno,ename,sal,deptno) values(9527,'hua%an',100,40);
--如果往表中所有的列都添加数据时,表后面的字段可以不添加,直接写values
insert into emp values(8888,'xiaoqiang','aaa',9527,sysdate,0,null,40);
--查询结果式的插入
--语法2:insert into tablename sub-query
--例子:
insert into emp_temp (select * from emp where deptno = 20)
--创建一个emp的临时复制表
create table emp_temp as select * from emp where 1 = 2
--delete关键字
--作用:删除表中的数据
--语法:delete [from] tablename [where condition]
--例子:
delete emp_temp where empno = 8888;
delete from emp_temp;
--update关键字
--作用:更新表中的数据
--语法:update tablename set column1=value1,column2=value2,...,columnN=valueN [where condition]
--例子:
update emp_temp set sal = sal*1.2 where ename = 'SMITH';
select * from emp_temp;
select * from emp_temp
--转账
update emp_temp set sal = sal - 500 where ename='JONES';
update emp_temp set sal = sal + 500 where ename='SMITH';
commit;
rollback;
create table aaa(id number,name varchar2(20));
--savepoint 存档点
insert into emp_temp(empno,ename) values(1111,'cai10');
insert into emp_temp(empno,ename) values(2222,'cai20');
savepoint sp1;
insert into emp_temp(empno,ename) values(3333,'cai30');
insert into emp_temp(empno,ename) values(4444,'cai40');
rollback to sp1;
--事务的四个特性:ACID
--原子性(A)
--一致性(C)
update emp_temp set sal = 5000 where empno=1111
update emp_temp set sal = sal+1000 where empno = 1111;
--隔离性(I)
--持久性(D)
--用户管理
--1.创建一个账户
create user zhangsan identified by 123456;
--2.修改账户的密码
alter user zhangsan identified by 654321;
--3.删除一个账户 [cascade 表示是否级联删除]
drop user zhangsan;
--4.让一个用户的密码失效
alter user zhangsan password expire;
--5.锁定、解锁一个账户
alter user zhangsan account lock;
alter user zhangsan account unlock;
--DCL
--grant授予权限
--revoke收回权限
--1.给用户授权
--允许用户登录
grant create session to zhangsan;
--给账户授权可以操作表
grant all on scott.emp_temp to zhangsan;
--2.取消用户的权限
revoke all on scott.emp_temp from zhangsan;
--创建序列
create sequence seq_emp_temp
increment by 1
start with 1
--使用序列
--通过序列名.next_val
select seq_emp_temp.nextval from dual;
select seq_emp_temp.currval from dual;
insert into emp_temp(empno) values(seq_emp_temp.nextval)
select * from emp_temp;
--登录到sys账户给scott赋予创建视图的权限
grant create view to scott;
--1.视图的创建
create view v$_emp_dept
as
select ename,sal,job,dname from emp,dept where emp.deptno = dept.deptno;
--视图也可以从视图中产生
create view v$_emp_dept_tem
as
select ename,sal from v$_emp_dept
--修改视图的数据,就是修改基表的数据
create or replace view v$_emp
as
select empno,ename from emp
with read only
select * from v$_emp;
select * from emp;
update emp set sal = 8888 where empno = 9527;
--视图的优点:可以使某些重复出现SQL语句变得更为简单
--视图的缺点:1.如果修改基表的结构,视图失效
-- 2.增加数据库的维护成本
-- 3.视图会被覆盖掉
-- 4.一般情况下,不要对视图进行DML操作
--视图的例子
select dname, grade
from (select deptno, avg_sal, grade
from (select deptno, avg(sal) avg_sal from emp group by deptno) t,
salgrade s
where t.avg_sal between s.losal and s.hisal) t1,
dept
where t1.deptno = dept.deptno
and t1.grade =
(select min(grade)
from (select deptno, avg_sal, grade
from (select deptno, avg(sal) avg_sal
from emp
group by deptno) t,
salgrade s
where t.avg_sal between s.losal and s.hisal));
--为上面的SQL中重复出现的sql语句创建视图
create view v$_dept_avgsal
as
select deptno, avg_sal, grade
from (select deptno, avg(sal) avg_sal from emp group by deptno) t,
salgrade s
where t.avg_sal between s.losal and s.hisal
--利用视图替换上面的sql语句
select dname, grade
from v$_dept_avgsal t1,
dept
where t1.deptno = dept.deptno
and t1.grade =
(select min(grade)
from v$_dept_avgsal);
--删除视图所表示的基表
create view v$_aaa
as
select * from aaa;
--删除表 aaa
drop table aaa;
--查询视图
select * from v$_aaa;
--删除视图 v$_aaa
drop view v$_aaa;
--DDL
--create
--作用:用来创建数据库的对象(表,视图,序列,索引等)
--语法1:create table tablename(column1 dataType, column2 dataType,...,columnN dataType)
--例子:
create table t_user(
id number,
username varchar2(30),
password varchar2(30)
);
--语法2:create table tablename as subquery
--例子:
create table emp_e1 as select * from emp where 1=1;
--alter
--作用:用来修改数据库的对象(表,视图,序列,索引等)
--语法:alter table tablename [modify/add/drop]
--例子1:
alter table emp_e1 modify(ename varchar2(10));
insert into emp_e1(empno,ename) values(9898,'cai10cai10cai');
--例子2:
alter table emp_e1 add(phone varchar2(11));
--例子3:
alter table emp_e1 drop column phone;
select * from emp_e1
--drop
--作用:用来删除数据库的对象(表,视图,序列,索引等)
--语法 drop table tablename
drop table emp_e1;
SQL 序列-DML-DML-数据类型-用户管理、权限-事务-视图的更多相关文章
- Oracle 用户管理权限
Oracle 用户管理权限 一.创建用户的Profile文件 SQL> create profile student limit // student为资源文件名 FAILED_LOGIN_AT ...
- Linux_用户管理&权限管理
2017年1月11日, 星期三 Linux_用户管理&权限管理 1. Linux用户管理&权限管理 终端的概念: tty 查看登录的终端 类型 user group oth ...
- Ubuntu 用户管理/权限管理
Ubuntu 用户管理/权限管理 小小记录一下 Ubuntu 下用户/权限管理常用的一些命令 用户管理 组管理 文件权限 给用户添加 sudo 权限 给用户添加 sudo 权限 首先先给出几个文件 / ...
- mysql用户管理,权限管理
mysql权限 相关操作: 授予的权限分为四组: 列权限:和表中的一个具体列相关,例如:使用update 语句更新test表中name 列的值 表权限:和一个具体的表的所有数据相关,例如:使用 sel ...
- CRM、用户管理权限
CRM目录结构 from django.shortcuts import HttpResponse,render,redirect from django.conf.urls import url f ...
- Oracle用户角色权限相关视图
常用相关视图概述 DBA_SYS_PRIVS: 查询某个用户所拥有的系统权限 USER_SYS_PRIVS: 当前用户所拥有的系统权限 SESSION_PRIVS: 当前用户所拥有的全部权限 ROLE ...
- mysql 用户管理 权限控制
添加用户 insert into mysql.user(Host,User,Password) values("%","shenen",password(&qu ...
- Linux用户管理 权限管理 内存管理 网络管理命令 (第四天)
默认添加的用户会自动加入和用户名一样的组中su 切换用户查看当前登陆的用户: whoami id`查看当前用户属于哪个组:groupsgroupadd 组名 添加组groupdel 组名 删除组gre ...
- jenkins 添加用户管理权限
一.前言 小组开会通知 想把jenkins 构建的权限给开发,这样的话效率会增加.运维也不必每次帮助开发去构建发布. 1.规划 jenkins 四个项目分别对应三个人负责.项目下的只负责 CI.UAT ...
随机推荐
- Anaconda+django安装问题
Anaconda使用中常遇到如下问题: 如果Anaconda不是最新版本,可在Anaconda Prompt中使用如下命令更新至最新版 conda update -n base -c defaults ...
- 网络知识 - 简易的自定义Web服务器
简易的自定义Web服务器 基于浏览器向服务端发起请求 两台主机各自的进程之间相互通信,需要协议.IP地址和端口号,IP表示了主机的网络地址,而端口号则表示了主机上的某个进程的地址,IP加Port统称为 ...
- torch分类问题
import torch from torch.autograd import Variable import torch.nn.functional as F import matplotlib.p ...
- NB-IoT省电模式:PSM、DRX、eDRX【转】
转自:https://blog.csdn.net/zoomdy/article/details/80447372 NB-IoT支持三种省电模式:PSM (Power Saving Mode,省电模式) ...
- Python 官方中文教程(简)
Python 官方教程 前言 这是一次系统学习Python官方教程的学习笔记 整个教程一共16章, 在学习过程中记录自己不知道的和一些重要的知识, 水平有限, 请指正. Python3.7 官方教程. ...
- Centos6.X搭建Squid为YUM做代理
1.在能联网的机器上安装 Squid yum install squid 2.配置squid vi /etc/squid/squid.conf 编辑内容如下: http_port cache_mem ...
- PHP实用工具类
2018年10月25日 20:21:09 组装SQL语句 适用MySQL, 链式调用, 组装后可传参选择是否查询数据库 项目地址: 码云 生成数据字典 适用MySQL, 链式调用, 可生成word, ...
- 【原创】大叔经验分享(9)yarn重要配置yarn.nodemanager.local-dirs
yarn中有一个比较重要的配置yarn.nodemanager.local-dirs,如果配置的不好,在饱和状态运行下集群会出现很多问题:1 默认配置${hadoop.tmp.dir}/nm-loca ...
- 【原创】运维基础之Docker(7)关于docker latest tag
Docker images have a tag named latest which doesn’t work as you expect.Latest is just a tag with a s ...
- VUE 多页面配置(二)
1. 概述 1.1 说明 项目开发过程中会遇到需要多个主页展示情况,故在vue单页面的基础上进行配置多页面开发以满足此需求,此记录为统一配置出入口. 2. 实例 2.1 页面配置 使用vue脚手架搭建 ...