文档章节

oracle笔记——杂记篇

红焖鲤鱼
 红焖鲤鱼
发布于 2015/04/12 16:53
字数 2232
阅读 146
收藏 5

一、创建表的知识

    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.1delete语句

        

                    (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              --不循环,CYCLENOCYCLE 表示当序列生成器的值达到限制值后是否循环

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_operatorTB_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中的ASIS的不同,以及使用,两者基本上没有不同 

ASISORACLE为了方便而设置的同义词。

何时使用

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

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+1from dual

    每天早上830         ''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/243 ), ''Q'' ) -1/24''

    每星期六和日早上610    ''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窗口将保持显示

        2pl/sql中设置自动提示

        

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

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

        3PL/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;

 

 

© 著作权归作者所有

共有 人打赏支持
红焖鲤鱼
粉丝 113
博文 40
码字总数 29610
作品 0
浦东
QA/测试工程师
Spring.NET学习笔记——目录(原)

目录 前言 Spring.NET学习笔记——前言 第一阶段:控制反转与依赖注入IoC&DI Spring.NET学习笔记1——控制反转(基础篇) Level 200 Spring.NET学习笔记2——环境搭建(基础篇) Level 200 Sprin...

长平狐
2012/06/11
887
1
Mini 容器学习笔记1——环境搭建(基础篇)

一. 环境下载 到Mini 容器的官方网站下载NLite框架的二进制文件,下载并解压后就可以了。 我们使用NLite框架需要用到下面的文件: NLite.dll(必要) 二. 建立NLite应用程序 新建一个控制台应用...

netcasewqs
2011/08/26
0
0
springboot集成log4j2【JWordPress前台项目实战】

写在前面 在任何系统中,日志都是非常重要的组成部分,它是反映系统运行情况的重要依据,也是排查问题时的必要线索。绝大多数人都认可日志的重要性,但是又有多少人仔细想过该怎么打日志,日...

技术小能手
07/23
0
0
阅读杂记(RSA,PDO)

RSA算法 RSA Key Size Selection http://www.vocal.com/cryptography/rsa-key-size-selection/ 这篇文章说的是如何选择RSA密钥的长度。RSA密钥的长度是可以选择的,RSA密钥的长度影响加密后的...

王二狗子11
01/08
0
0
Cocopods的升级错误解决

写在前面: 这篇笔记的由来,是因为在这个周五下班后想起了之前 上一个关于 的 仍处于未完待续的状态。便想着完成了它,遂打开了该工程,开始用 更新第三方库。更新完 管理的三方库,看到提示...

Mr_zebra
10/16
0
0

没有更多内容

加载失败,请刷新页面

加载更多

TypeScript基础入门之JSX(一)

转发 TypeScript基础入门之JSX(一) 介绍 JSX是一种可嵌入的类似XML的语法。 它旨在转换为有效的JavaScript,尽管该转换的语义是特定于实现的。 JSX在React框架中越来越受欢迎,但此后也看到了...

durban
27分钟前
0
0
JavaScript使用原型判断对象类型

1. constructor属性 在JavaScript创建对象(二)——构造函数模式中,我们说过可以使用对象的constructor属性判断对象的类型:p1.constructor === Person,可能当时就有细心的读者会想,我们...

Bob2100
29分钟前
1
0
10-《深度拆解JVM》JVM是怎么实现invokedynamic的?(下)

一、问题引入 上回讲到,为了让所有的动物都能参加赛马,Java 7 引入了 invokedynamic 机制,允许调用任意类的“赛跑”方法。不过,我们并没有讲解 invokedynamic,而是深入地探讨了它所依赖...

飞鱼说编程
49分钟前
2
0
457. Circular Array Loop

Description Difficulty : Medium You are given an array of positive and negative integers. If a number n at an index is positive, then move forward n steps. Conversely, if it's n......

52iSilence7
今天
1
0
MySQL SQL 常见用法

某字段重复记录 select a.fieldA from tableA a group by a.fieldA having count(a.fieldA)>1;==select * from (select a.fieldA, count(1) as faCount from tableA a group......

园领T
今天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部