oracle学习笔记第三天
--DML(Data Manipulation Language)
--insert关键字 插入
---语法1、元祖值式插入(一次插入一条记录)
---格式:insert into 表名(列名1,列名2...列名n) values(值1,值2...值n)
insert into emp(ename,empno) values('xiaoqiang',7100);
---注:当插入一条包含所有列的数据时,可以省略表后面的字段。
insert into emp values(6682,'hong','clerk',9527,sysdate,0,null,40);
---语法2、查询结果式插入
---格式:insert into 表名 子表查询语句
insert into emp_temp (select * from emp where deptno=20);
---创建一个emp的临时复制表
create table emp_temp as select * from emp where 1=2;
--delete关键字 删除表中的数据
--语法:delete [form] 表名 [where 条件]
select * from emp_temp;
delete emp_temp where empno = 7566;
--注:delete 表民 删除的是整个表的数据,表此时是空表
--如果想从表中删除所有的行,丌要使用delete,可使用truncate table 语
--句,完成相同的工作,但是速度更快(没有事务)。
--update关键字 更新表中的数据
--语法:update 表名 set 列名1=值1,列名2=值2,...列名n=值名n [where 条件]
update emp_temp set sal=800 where empno=7369;
--事务(Transaction) 保证数据的完整性,不可嵌套
--是一个操作序列。这些操作必须同时发生,是不可分割的,是数据库环境中的逻辑工作单位。
--例如:转账时必须保证a转出钱与b收到钱同时发生,不能分割开;
--开启事务:一条DML(insertm,update,delete)语句
--关闭事务:1、回退:用户使用rollback;系统奔溃或断电时自动回退
2、提交:用户使用commit语句
用户使用DDL(create、alter、drop)语句事务自动提交
用户正常断开连接时,自动提交
select * from emp_temp;
update emp_temp set sal=sal-100 where empno=7369;
update emp_temp set sal=sal+100 where empno=7369;
---commit关键字 提交事务
---rollback关键字 回退事务(事务不提交)
---savepoint 存档点 可设置存档点,回退时可选择回退(rollback to)到哪个存档点,此时事务并未关闭
update emp_temp set sal=sal-100 where empno=7369;
savepoint sp01;
update emp_temp set sal=sal-100 where empno=7369;
rollback to sp01;
commit;
select * from emp_temp;
--事务的ACID属性
---原子性(Atomicity)
---一致性(consistency)
---隔离性(isolation)
---持久性(durability)
--用户管理 DCL
---1、创建一个用户
create user xiaoming identified by 123456;
---2、修改账户的密码
alter user xiaoming identified by 333777;
---3、删除一个账户
drop user xiaoming;
---4、让一个用户的密码失效
alter user xiaoming password expier;
---5、锁定、解锁一个账户
alter user xiaoming account lock;
alter user xioaming account unlock;
--给用户授权 grant
---1、允许用户登录
grant create session to xiaoming;
---2、允许操作表
grant all on scott.emp to xiaoming;
--取消用户的权限 revoke
revoke all on scott.emp to xiaoming;
--序列 sequence
--oracle 专有的对象,产生一个自动递增的数列
--创建序列的语法 :create sequence 序列名 increment by 递增值 start with 开始值
create sequence seq_emp_temp
increment by 1
start with 1
---序列的使用
---nextval 下一个值
---currval 最近的值
insert into emp_temp (empno,ename) values
(seq_emp_temp.nextval,'lisi');
select * from emp_temp;
select seq_emp_temp.nextval from dual;
select seq_emp_temp.currval from dual;
--view 视图 (建议名字以v$_开头) 一种不占用物理空间的虚表
---作用:将一些复杂的sql语句设置为视图,便于chaxun,建议只用于查询
---语法:create [or replace] view 视图名 as 子查询 [with read only]
---注:1.视图可以由物理表或视图产生
--- 2.产生视图的表称为基表
3.视图与基表是同一份数据
4.不能对多表的数据通过视图修改
---使用视图需要注意
1.一般来讲,只有重复出现非常多次的SQL语句,才会创建视图
2.数据库迁移,视图也得随之迁移,否则在新数据中是不能用的
3.创建视图时,尽量不要带or replace
---先用sys账户给scott授权,再切回scott账户操作
grant create view to scott;
create view v$_emp as select ename from emp;
---查询视图与查询表一样
select * from v$_emp;
---删除视图
drop view v$_aaa;
--DDL(Data definition language)
---1.create关键字 创建数据库的对象(表、视图、序列、账户等)
---语法格式1:creat table 表名 (列名1 数据类型,列名1 数据类型 ...列名n 数据类型)
---语法格式2:creat table 表名 as 子查询
create table grade (gname varchar2(30),gra number(10,0));
select * from grade;
insert into grade(gname,gra) values('小红',99);
---2.alter 关键字 修改数据库的对象(表、视图、序列、账户等)
---语法格式1:alter table 表名 add(列名 数据类型)===> 添加列
---语法格式2:alter table 表名 modify(列名 数据类型)===>修改列
---语法格斯3:alter table 表名 drop(列名) ===> 删除列
alter table grade add(gender varchar2(3));
alter table grade modify(gender varchar(10));
alter table grade drop(gender);
---3.drop关键字 删除数据库的对象(表、视图、序列、账户等)
---语法格式:drop table 表名
drop table grade;
--数据类型
---数据类型分类:
1.number(x,y) 数字类型,x表示最大长度,y表示精度
2.varchar2(x) 可变字符串,x表示最大长度
3.char(x) 定长字符串,x表示最大长度
4.long 长字符串,最大2G
5.Date,日期(年月日时分秒)
6.TIMESTAMP 时间戳,精确到微秒
oracle学习笔记第三天的更多相关文章
- oracle学习笔记(三)oracle函数
--oracle 函数 --lower(char):将字符串转换为小写格式 --upper(char):将字符串转换为大写格式 --length(char):返回字符串的长度 --substr(cha ...
- oracle学习笔记(三)
索引: drop table test1 purge; drop table test2 purge; drop table test3 purge; drop table t purge; crea ...
- Oracle 学习笔记(三)
1.插入有日期的表,使用 to_date 函数 to_date('1992-12-07', 'yyyy-mm-dd'); 2.使用update更新语句的时候,既可以使用表达式或者数值直接修改数据,也可 ...
- oracle学习笔记(三) DCL 数据控制语言与 DDL 数据定义语言
DCL 数据控制语言 Data control language 之前说过的授权和收权利语句 grant, revoke DDL 数据定义语言 Data define language create ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- Django学习笔记(三)—— 型号 model
疯狂暑期学习 Django学习笔记(三)-- 型号 model 參考:<The Django Book> 第5章 1.setting.py 配置 DATABASES = { 'defaul ...
- oracle学习笔记第一天
oracle学习笔记第一天 --oracle学习的第一天 --一.几个基础的关键字 1.select select (挑选) 挑选出显示的--列--(可以多列,用“,”隔开,*表示所有列),为一条 ...
- Oracle学习笔记—数据字典和常用命令(转载)
转载自: oracle常用数据字典和SQL语句总结 Oracle常用命令大全(很有用,做笔记) 一.Oracle数据字典 数据字典是Oracle存放有关数据库信息的地方,其用途是用来描述数据的.比如一 ...
- PyQt4入门学习笔记(三)
# PyQt4入门学习笔记(三) PyQt4内的布局 布局方式是我们控制我们的GUI页面内各个控件的排放位置的.我们可以通过两种基本方式来控制: 1.绝对位置 2.layout类 绝对位置 这种方式要 ...
随机推荐
- JS禁用浏览器退格键、禁止右键、禁止全选、复制、粘贴
一.禁用浏览器退格键 摘抄自:https://www.cnblogs.com/wanggd/p/3164536.html 我们在真实的项目开发中经常会使用JS 对键盘上的一些按键进行禁用,常见的比如说 ...
- Hive快捷查询:不启用Mapreduce job启用Fetch task三种方式介绍
如果查询表的某一列,Hive中默认会启用MapReduce job来完成这个任务,如下: hive>select id,name from m limit 10;--执行时hive会启用MapR ...
- 微信小程序语音与讯飞语音识别接口(Java),Kronopath/SILKCodec,ffmpeg处理silk,pcm,wav转换
项目需求,需要使用讯飞的语音识别接口,将微信小程序上传的录音文件识别成文字返回 首先去讯飞开放平台中申请开通语音识别功能 在这里面下载sdk,然后解压,注意appid与sdk是关联的,appid在初始 ...
- elasticsearch-5.2.1在windows下的安装方法
elasticsearch-5.2.1安装方法 1. 安装java 下载安装java jdk 1.8 以上 配置java环境变量 右击[我的电脑]---[属性]-----[高级系统设置]---[环境变 ...
- linux基础命令学习笔记(一)
2019年4月1日: “目录” = “文件夹” 常用命令(一): 1.ls: list 列表,默认当前文件夹的文件和目录 linux:命令+选项+参数 ls -l:长输出,列出文件的详细信息 - rw ...
- 安装酷痞到IIS7.x共用80端口Windows(64位)系统下运行多个酷痞
需求: 1.酷痞直接运行的模式是自宿主运行.由于win系统一般都由iis提供多个网站服务,并首先占用了80端口,如果想酷痞可以直接通过主机头和iis共用80端口会出现这种运行模式的需求. 以下是实现方 ...
- python输出
学习之前普及一个知识,在python2.X的版本中是不可以输入中文的,如果一定要输入中文就必须要在整段代码的最上面第一行备注一下:# _*_ coding:utf-8 _*_ print函数,这是一个 ...
- .net 枚举类型转换
数字转化名称 Enum.GetName(typeof(枚举), 数字); 名称转化数字 (int)枚举
- Tomcat目录结构详解
1.bin: 该目录下存放的是二进制可执行文件,如果是安装版,那么这个目录下会有两个exe文件:tomcat6.exe.tomcat6w.exe,前者是在控制台下启动Tomcat,后者是弹出UGI窗口 ...
- 《MySQL必知必会》整理
目录 第1章 了解数据库 1.1 数据库基础 1.1.1 什么是数据库 1.1.2 表 1.1.3 列和数据类型 1.1.4 行 1.1.5 主键 1.2 什么是SQL 第2章 MySQL简介 2.1 ...