oracle笔记——杂记篇

Wesley13
• 阅读 522

一、创建表的知识

1、创建表

_--_用户信息

create table tb_operator(

Id Int primary key,_--_自动编号

Name Varchar2(12),_--_姓名

Sex Varchar2(2),_--_性别

Age int,_--_年龄

Identitycard Varchar2(12),_--_证件号码

Workdate date ,_--_办证日期

Tel Varchar2(12) ,_--_电话号码

keepMoney number ,_--_押金

Password Varchar2(12) ,_--_密码

admin Varchar2(10)_--_管理员

);

2、为表和各列添加注释信息

comment on table tb_operator is '用户信息';

comment on column tb_operator.id is '自动编号';

comment on column tb_operator.Name is '姓名';

comment on column tb_operator.Sex is '性别';

comment on column tb_operator.Age is '年龄';

comment on column tb_operator.Identitycard is '证件号码';

comment on column tb_operator.Workdate is '办证日期';

comment on column tb_operator.Tel is '电话号码';

comment on column tb_operator.keepMoney is '押金';

comment on column tb_operator.Password is '密码';

comment on column tb_operator.admin is '管理员';

3、对tb_operator 表进行插入一列yajin

alter table 表名 add 列名称 VARCHAR2(2)

alter table tb_operator add yajin VARCHAR2(2)

4、----修改yajin列名称为test

alter table 表名 rename column 原名称 to 新名称;

alter table tb_operator rename column yajin to test;

5、----删除test列

alter table 表名 drop column 列名

alter table tb_operator drop column test

6、删除表

drop table 表名;

7、修改表字段长度

alter table 表名 modify (字段名 字符类型 长度)

_--_将__tel__字段长度由__12__位改为__18__位

alter table tb_operator modify (tel varchar2(18) )

二、对表中内容操作

1、在表中插入数据

            insert into 表名(列1,列2,列3,.......)

            values('值1','值2','值3',............);

            insert into tb_operator(name,sex,age,identityCard,workdate,tel,password,keepmoney)

            values('测试','1',21,'123456789123456789','2014-03-07','1500000000','20','20');

            注意:插入数据后要commit

2、对表数据进行修改

            update 表名 t set 列=replace(列,'修改前的内容','修改后的内同')

            where t.列2='唯一定位数据的值'

            _--_将姓名为__“__测试__”__的年龄由__21__岁改为__18__岁

            update tb_operator t set age=replace(age,'21','18')

            where t.name='测试'

3、删除表内容

3.1、delete语句

             (1)有条件删除

             语法格式:delete from 表名 where 条件;

             如:删除tb_operator表中的name为‘测试’的数据:delete from tb_operator where name='测试';

             (2)无条件删除整个表数据

             语法格式:delete 表名;

             如:删除tb_operator表中的所有数据:delete tb_operator;

3.2Truncate语句

由于delete语句删除记录时候,记录是逐条删除的,而Truncate 语句删除数据时不产生回退信息;所以如果需要删除大量数据的时候使用delete则占用较多的系统资源,而如果使用Truncate 则会快的多

三、序列与触发器

    在例子当中创建用户信息表的时候我们会发现字段当中的ID是自动增加的,那么我们如何子数据库中自动增加呢,这里我们用到了序列和触发器的组合

1、序列

(1)、首先我们要创建序列

格式:

Create Sequence 序列名称

increment by 1 _--_增长度

start with 1 _--_从哪里增加,就是说下一个获取的值从这个值开始

nomaxvalue _--_不设置最大值

order _--_指定一定往下增加

nocycle _--_不循环,__CYCLE__和__NOCYCLE 表示当序列生成器的值达到限制值后是否循环

cache 10 _--CACHE(缓冲)_定义存放序列的内存块的大小,默认为__20

例子: 创建序列名称为 TB_ID_SEQ

CREATE SEQUENCE TB_ID_SEQ

INCREMENT BY 1 _--_每次增加__1

START WITH 1; _--_从__1__开始

(2)、查询创建的序列

select TB_ID_SEQ.nextval from dual;

select TB_ID_SEQ.currval from dual;

需注意:

第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。CURRVAL 总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。

(3).修改序列

序列的某些部分也可以在使用中进行修改,但不能修改SATRT WITH选项。对序列的修改只影响随后产生的序号,已经产生的序号不变。修改序列的语法如下:

ALTER SEQUENCE TB_ID_SEQ

INCREMENT BY 10

MAXVALUE 10000

CYCLE -- 到__10000__后从头开始

NOCACHE ;

(4).删除序列

DROP SEQUENCE TB_ID_SEQ;

2、触发器

_--建立一个触发器:_将表和序列联系起来

格式:

CREATE OR REPLACE TRIGGER 触发器名称

BEFORE INSERT ON 表名

FOR EACH ROW

BEGIN

SELECT 序列名称.NEXTVAL INTO :NEW.自增的字段 FROM DUAL;

END TR_FCBOOK;

例子:创建一个TRG_TB_ID的触发器将表tb_operator和TB_ID_SEQ联系起来实现Id的自增

CREATE OR REPLACE TRIGGER TRG_TB_ID

BEFORE INSERT ON tb_operator

FOR EACH ROW

BEGIN

SELECT TB_ID_SEQ.NEXTVAL INTO :NEW.Id FROM DUAL;

END;

_--_删除触发器

--DROP TRIGGER TRG_TB_ID;

_--_测试数据插入,查看__ID__是否自动增加

-- insert into tb_operator(name,sex,age,identityCard,workdate,tel,password,keepmoney)

values('测试','1',21,'123456789123456789','2014-03-07','1500000000','20','20');

四、存储过程

百度百科:存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它

格式:

create or replace procedure 存储过程名称 is

begin_--_执行部分

操作;

commit;

end;

例子:在这里我们创建一个名称为sp_prol简单的存储过程,实现向表tb_operator插入数据

create or replace procedure sp_prol is

begin_--_执行部分

insert into tb_operator(name,sex,age,identityCard,workdate,tel,password,yajin)

values('超人','1',21,'123456789123456789','2014-03-07','150000000','20','20');

commit;

end;

注:Oracle中的AS和IS的不同,以及使用,两者基本上没有不同 。

AS和IS是ORACLE为了方便而设置的同义词。

何时使用

1、在创建存储过程(PROCEDURE)/函数(FUNCTION),以及自定义类型(TPYE)和包(PACKAGE)时,使用AS和IS无区别。

2、在创建视图(VIEW)时,只能使用AS而不能使用IS。

3、在声明游标(CURSOR)时,只能使用IS而不能使用AS

五、定时器

    格式:

    _--_定时器

    declare

     job number;

    begin

     sys.dbms_job.submit(

     job, _--_定时器__ID__,系统自动获得

     'sp_prol;',_--_执行的过程名

     sysdate, _--_定时器开始执行的时间,这样写表示立即执行

     'SYSDATE + 1/(60*24)');_--interval,_设置定时器执行的频率,这样写每隔__1__分钟执行一次

     commit;

    end;

    可以看出一般情况我们配置定时器时只需要改动一下存储过程和执行时间就可以,其中时间在实际中会经常用到

    我们来补充一下

    补充:

    描述 INTERVAL参数值

    每天午夜12点 ''TRUNC(SYSDATE + 1)''

    _---_测试可以用__dual__表查查看

    select trunc(sysdate+1) from dual

    每天早上8点30分 ''TRUNC(SYSDATE + 1) + (8*60+30)/(24*60)''

     --8__个小时*60__分钟+30__分钟/一天__24__个小时*60__分钟

    每星期二中午12点 ''NEXT_DAY(TRUNC(SYSDATE ), ''''TUESDAY'''' ) + 12/24''

    每个月第一天的午夜12点 ''TRUNC(LAST_DAY(SYSDATE ) + 1)''

    每个季度最后一天的晚上11点 ''TRUNC(ADD_MONTHS(SYSDATE + 2/24, 3 ), ''Q'' ) -1/24''

    每星期六和日早上6点10分 ''TRUNC(LEAST(NEXT_DAY(SYSDATE, ''''SATURDAY"), NEXT_DAY(SYSDATE, "SUNDAY"))) + (6¡Á60+10)/(24¡Á60)''

    select job,broken,what,interval,t.* from user_jobs;

     参数介绍

     job job的唯一标识,自动生成的

     broken 是否处于运行状态,N;运行;Y:停止

     what 存储过程名称

     interval 定义的执行时间

    _--删除定时任务,_括号里为__user_jobs__表中__job__字段的编号到

    begin dbms_job.remove(26);

    commit;

    end;

六、Pl/Sql Developer设置小技巧

1、显示window list窗口

默认情况下Window List窗口是不显示的,这十分不方便

(一)在菜单项的Tools下的Preference选项中的User Interface中选择Option,在右边对于的Autosave desktop中把前面的复选框勾选上。

(二)在菜单项的Tools下的Window list选项勾上。

通过上面两步设置,关闭后下次打开Window List窗口将保持显示

2、pl/sql中设置自动提示

如输入表名+'.'后不自动弹出提示列名的做法:

在Tools->preperences->code assistant 界面里把automatically activated取消即可;如果想让它自动提示, 选中即可。

3、PL/SQL记住登陆密码

在使用PL/SQL Developer时,为了工作方便希望PL/SQL Developer记住登录Oracle的用户名和密码;
设置方法:PL/SQL Developer 7.1.2 ->tools->Preferences->Oracle->Logon History , “Store history”是默认勾选的,勾上“Store with password” 即可,重新登录在输入一次密码则记住了。

4、PLSQL不修改tnsname直接连数据库的方式在PLSQL的Database中直接输入192.1

PLSQL 不修改tnsname直接连数据库的方式
在PLSQL的Database中直接输入192.168.1.6:1521/VP。
其中192.168.1.6为数据库的IP;
1521为数据库端口;
VP为数据库的SID。

七、创建查询用户search

create user search identified by search

default tablespace BD_DATA

temporary tablespace TEMP;

--授予连接权限

grant connect to search;

--授予查询任何表

grant select any table to search;

--授予 查询任何字典

grant select any dictionary to search;

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Wesley13 Wesley13
2年前
Java获得今日零时零分零秒的时间(Date型)
publicDatezeroTime()throwsParseException{    DatetimenewDate();    SimpleDateFormatsimpnewSimpleDateFormat("yyyyMMdd00:00:00");    SimpleDateFormatsimp2newS
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
4个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这