oracle基础——表、记录、字段的增删改查操作总结

小郝不负流年
小郝不负流年   + 关注
2021-01-14 21:20:27   阅读576   评论0

1、对表的增删改

drop table t_usr;  -- 删除表

alter table t_usr rename to t_usr2; -- 修改表名

create table t_usr(   -- 创建表

  id number(32),

  name varchar2(32) not null,

  age number(2) check(age>0 and age<100)

);

2、对表的记录进行增删改查

insert into t_usr(id,name,age) values(3,'Ja23ck',19); --增

delete from t_usr where age>18;                     --删

update t_usr set name='Jack2',age=20 where id=1;    --改

select * from t_usr where age>10;                   --查

3、对表的字段进行增删改查

alter table t_usr add(sex varchar2(2)); -- 增加一个新的字段

alter table t_usr drop column age;      --删除字段

alter table t_usr rename column name to sname; --更改字段名

alter table t_usr modify(name varchar2(16)); --修改字段的类型和范围

desc t_usr;                               -- 查询表结构

comment on column t_usr.name is '用户名';  -- 给某个字段添加注释

4、查询表的主键以及主键所在列位置

select * from user_cons_columns where constraint_name = 

(select constraint_name from user_constraints where

table_name = upper('表名') and constraint_type  ='P' );

5、删除表中重复数据                      

CREATE TABLE mytemp AS (select distinct * FROM t_usr); -- 创建临时表,并把DISTINCT 去重后的数据插入到临时表中

DELETE FROM t_usr;--清空原表数据

INSERT INTO t_usr (SELECT * FROM mytemp);-- 将临时表数据插入到原表中

DROP TABLE mytemp;--删除临时表

commit;

6、where 1=1 的应用

不是什么高级的应用,也不是所谓的智能化的构造,仅仅只是为了满足多条件查询页面中不确定的各种因素而采用的一种构造一条正确能运行的动态SQL语句的一种方法

-- where 1=0 这个条件始终为false,结果不会返回任何数据,只有表结构,可用于快速建表

create table t_usr_new as (select * from t_usr where 1=0);

7、删除数据的恢复

-- 第一步:在v$sqlarea 这视图里面找到你操作那条SQL的时间;

select r.FIRST_LOAD_TIME,r.* from v$sqlarea r WHERE r.sql_text LIKE '%UPDATE EMS_RS_MULT_LANG lang%' order by r.FIRST_LOAD_TIME DESC;

-- 检查是否此时间唯一的执行了sql

select r.FIRST_LOAD_TIME,r.* from v$sqlarea r WHERE r.first_load_time = '2018-07-10/11:22:02' order by r.FIRST_LOAD_TIME DESC;

-- 第二步: 备份数据到表

create table t_table_recove --新表

as

select * from EMS_RS_MULT_LANG --你操作的那张表 

as of timestamp to_timestamp('2018-07-10/11:22:02','yyyy-mm-dd hh24:mi:ss');

8、备份表

--创建一份表结构

create table tmp_ as select * from BASE_GOODSPAYMENT_SETTING ;

--将数据插入到备份表中

insert into tmp_ select * from BASE_GOODSPAYMENT_SETTING;


对我有用,我要     转载  
文章分类: 数据库   Oracle  
所属标签: oracle  
  • 0条评论
  • 只看作者
  • 按时间|按热度
  • 由于本人多次涉及需要打印这个证明,而每次都会忘记入口,在网上各种搜索各种摸索很是浪费时间。故本次将操作流程整理记录下来,以备忘。同时也分享给大家。1、打开湖北政务服务网,地址:http://zwfw.hubei.gov.cn/s/index.html2、切换区域到“武汉市”3、在“特色服务”模块找到“(个人)武汉市社会保险公共服务平台”4、进入“(个人)武汉市社会保险公共服务平台”,登录账号密码<imgsrc="https://cdnstatic.hoscen.cn/blog/article/184053017752895488/img/497065960be44747825acb86a17483c1.png"style=
  • 如何使用postman模拟http发送xml参数报文的POST请求?1、postman工具通过安装软件或使用谷歌插件都可以,这里不再赘述。2、配置postman,选择POST,填写URL;切换到Headers,添加Content-Type:text/xml 3、切换到body,选择raw,XML,下方填写你的请求报文4、点击Send发送请求,如图可以看到响应状态、时间、结果等信息5、讲到这里就结束了,是不是学会了?快去试试吧!
  • Failedtoloadprojectconfiguration:cannotparsefileF:/xx/.idea/modules.xml:ParseErrorat[row,col]:[1,1]Message:文件提前结束。解决办法:关闭idea,删掉这个文件,重新打开idea
  • 下载地址:https://adoptopenjdk.net/releases.html?variant=openjdk8&jvmVariant=hotspot选择文件类型:或者,你可以通过我的百度网盘分享直接获取:链接:https://pan.baidu.com/s/1UygOdTh6WNZyS5WP_API6w 提取码:phnh 注意:我这里是下载的32的jdk,你们如果要64位请下载64的。使用:使用上和OracleJDK使用上是没有区别的。区别:1.OracleJDK⼤概每6个⽉发⼀次主要版本,⽽OpenJDK版本⼤概每三个⽉发布⼀次。但这不是固定的,我觉得了解这个没啥⽤处。详情参⻅:https://blogs.oracle.com/java-platform-group/update-and-faq-on-the-java-se-release-cadence。 2.OpenJDK是⼀个参考模型并且是完全开源的,⽽OracleJDK是OpenJDK的⼀个实现,并不是完全开源的; 3.OracleJDK⽐OpenJDK更稳定。OpenJDK和OracleJDK的代码⼏乎相同,但OracleJDK有更多的类和⼀些错误修复。因此,如果您
  • 很多时候我们需要Linux服务器定时去运行一个脚本来触发一个操作,比如写缓存数据到硬盘、定时备份、定时重启服务、定期清除日志等。下面就简单讲解一下Linuxcrontab命令如何实现自动循环执行shell脚本。一、准备shell脚本比如我们准备一个hello.shvim/hcn/sh/hello.sh#!/bin/bash  DATETIME=$(date"+%Y%m%d%H%M%S") echo"hello, www.hoscen.cn,时间:${DATETIME}"  通过chmod命令赋予该脚本的执行权限chmod755hello.sh测试正确性二、开启crontab服务 linux应该都有crontab,没有的话可以安装一下:yuminstall vixie-cronyuminstall crontabsvixie-cron软
  • 目录:1、安装node.js环境2、安装cnpm3、安装vue-cli脚手架构建工具4、用vue-cli构建项目5、安装项目所需的依赖6、项目运行7、项目打包1、安装node.js环境下载地址:https://nodejs.org/zh-cn/安装过程没有太多好说的,安装完成后 win+R打开命令行输入node -v , 如图,出现版本号说明安装成功。npm包管理器是集成在node中的 , npm -v可以查看版本2、安装cnpm由于有些npm有些资源被屏蔽或者是国外资源的原因,经常会导致用npm安装依赖包的时
  • 本文讲触发el-dialog前动态修改窗口title的方法。1、el-dialog添加title属性el-dialog :title="titleType+'菜单'" :visible.sync="dialogVisible" width="800px" >el-dialog>  2、初始化变量(titleType,名称自己定义)export&
  • 建立服务器内网其他IP端口的隧道,可以将远程的服务映射到本地进行访问。finalshell配置隧道方法:
  • 一般我们在使用CDN时都设置有缓存时间,当源站资源发生变更后,如果缓存时间没到,那么用户访问的依旧是变更前的数据,虽说又拍云控制台提供了缓存刷新功能界面,但是每次都手动去刷新显示不太理想,当然又拍云也想到了这一点,提供给我们有API可以调用。本篇文章就是讲解如何接入又拍云缓存刷新API。网站免费接入又拍云CDN的方法,请查看我另外一篇文章,地址: https://www.hoscen.cn/blog/hao/articles/204022774975430656.html又拍云API文档:https://api.upyun.com/doc#/api/guide/overview看完文档,我们会知道又拍云提供有两个缓存刷新接口,一个支持通配符(但次数有限),一个是完整url刷新。同时注意调用接口时将 Token 放入 HTTP Header 中 。那么我们需要3个接口:1、获取token2、URL刷新3、缓存批量刷新详细请求参数和响应值请查看文档。话不多说,我们直接放上核心代码1、获取token2、URL刷新<img src="https://cdnstatic.hoscen.cn/blog/article/
  • SQL计算日期相差多少分钟,示例SELECT  ROUND(TO_NUMBER(to_date(rs.t_cap_wf_finReq_start_date,'YYYY/MM/DDhh24:mi:ss')-to_date(rs.t_cap_wf_start_date,'YYYY/MM/DDhh24:mi:ss'))*24*60) FROM table_xxx 更多差值单位写法天:ROUND(TO_NUMBER(END_DATE-START_DATE))小时:ROUND(TO_NUMBER(END_DATE-START_DATE)*24)分钟:ROUND(TO_NUMBER(END_DATE-START_DATE)*24*60)秒:ROUND(TO_NUMBER(END_DATE-START_DATE)*24*60*60)毫秒:ROUND(TO_NUMBER(END_DATE-START_DATE)*24*60*60*1000)