oracle 简单备注

1. 建立数据库

备注:

1) oracle 不同于mysql 可以直接create database

2) oracle 创建schema时对应一个用户,即该schema的访问用户,与用户一一对应;但可以存在多个访问用户(带权限控制)

1.1 创建数据库文件

CREATE TABLESPACE XX LOGGING DATAFILE ‘D:\app\XX\oradata\orcl\XX.dbf‘ SIZE 1000M;

create temporary tablespace XX tempfile ‘D:\app\XX\oradata\orcl\XX.dbf‘ size 1000m;

1.2 创建用户

CREATE USER XX IDENTIFIED BY XX DEFAULT TABLESPACE XX TEMPORARY TABLESPACE XX;

1.3 授权

grant connect, resource to XX;
grant create session to XX;

2. 数据库操作(默认sccot用户):

2.1 create

create table persons(
person_id NUMBER PRIMARY KEY,
first_name VARCHAR2(50) NOT NULL,
last_name VARCHAR2(50) NOT NULL,
score NUMBER,
type VARCHAR2(20)
);

备注:

1) ORA-02000: missing ALWAYS keyword : 在11g版本里不用用GENERATED BY DEFAULT AS IDENTITY ,要用PRIMARY KEY
2) oracle 本来只有number类型,用作number(19,2),即有小数位;后为了兼容其他数据库,新增int,只能是整形

2.2 insert

insert into persons values(1, ‘fred‘, ‘xu‘, 0, ‘a‘);

insert into persons values(SEQ_PERSON_ID.NEXTVAL, ‘fred3‘, ‘xu3‘, 0, ‘b‘)

备注:

1)oracle下设置自增没有mysql那么简单,步骤如下:

1.1) CREATE SEQUENCE SEQ_PERSON_ID start with 100; #创建一个序列
1.2) INSERT INTO persons VALUES(SEQ_PERSON_ID.NEXTVAL, ‘fred1‘, ‘xu1‘, 0, ‘a‘);

#此时插入persons表记录的person_id被设置成了100

1.3)也可以采用触发器的形式
CREATE TRIGGER persons_trigger
BEFORE INSERT ON persons
FOR EACH ROW
WHEN (new.person_id is null)
begin
select SEQ_PERSON_ID.nextval into :new.person_id from sys.dual;
end;

备注:sys.dual 是个虚拟表,oracle保证里面只有一条记录
:new— 触发器执行过程中触发表作操作的当前行的新纪录
:old— 触发器执行过程中触发表作操作的当前行的旧纪录

在有触发器之后,插入数据时不需要填写主键 INSERT INTO persons(first_name, last_name, score, person_type) VALUES(‘fred2‘, ‘xu2‘, 0, ‘a‘);

2.3 select

select * from persons where first_name = ‘fred‘ or last_name = ‘xu1‘
select * from persons where first_name like ‘%fred%‘
select * from persons where CONCAT(first_name, last_name) like ‘%1%‘

select * from users where rownum BETWEEN 0 AND 5 #利用rownum关键字分页

2.4 group by

select AVG(score), person_type from persons group by person_type
select AVG(score), person_type from persons group by person_type having person_type = ‘b‘

备注:

1)ORA-00979: not a GROUP BY expression group by 后的列要能被处理

2.5 in

select * from persons where person_type in (‘a‘,‘b‘);

2.6 insert all

insert all
into persons(first_name, last_name, score, person_type) values(‘test‘, ‘test‘, 1, ‘c‘)
into persons(first_name, last_name, score, person_type) values(‘test1‘, ‘test1‘, 1, ‘c1‘)
into persons(first_name, last_name, score, person_type) values(‘test2‘, ‘test2‘, 1, ‘c2‘)

SELECT 1 FROM dual;

备注:

SELECT 1 FROM dual; 最后一次select必须有

2.7 视图

create view person_view as select * from persons where first_name like ‘%f%‘

select * from person_view;

备注:

视图是需表,只是逻辑定义;除非是一种物化视图,那个才是有物理占用

2.8 索引

create index person_index on persons (first_name);

原文地址:https://www.cnblogs.com/Fredric-2013/p/8719641.html

时间: 2024-07-30 17:05:21

oracle 简单备注的相关文章

Oracle简单的备份和恢复-导出和导入(2)

ylbtech-Oracle:Oracle简单的备份和恢复-导出和导入(2) 简单的备份和恢复-导出和导入(2) 1. 用户导入导出文件中的一张表(emp)返回顶部 0.1, 我们在sql plus中删除掉一张表emp,把dept表的记录删空. drop table emp; delete from dept; 之后我们先利用刚才导出的mytable.dmp导入emp表.具体导入步骤如下: 1.在命令行下输入imp命令. 2.系统首先提示我们输入用户名和密码,在这里我们可以用scott/tige

oracle 简单SQL

1, insert into test select * from test;(造测试数据) 2, create table b as select * from a; (创建表结构一样的空表,数据可同上插入数据) 3,linux系统下让sqlplus支持历史命令回调 在linux中实现上述功能,需要一个小工具,叫做rlwrap,这个程式本身是个Shell,可以运行任何你提供给它的命令包括参数,并添加命令历史浏览功能. The rlwrap program is under the GPL li

Oracle简单的备份和恢复-导入和导出

ylbtech-Oracle:Oracle简单的备份和恢复-导入和导出  Oracle安全运行离不开良好的备份和恢复机制,因为我们不是DBA.所以我们也就不过多的讲解DBA的备份和恢复.作为程序员开发者来说,必须了解的是数据的导入和导出,利用这个方法我们可以搬迁数据库和数据. 1. 导出(exp)返回顶部 1.1, Oracle简单的备份和恢复-导出(exp) 1.2, 1.3, 2. 导入(imp)返回顶部 2.1, Oracle简单的备份和恢复-导入(imp) 2.2, 2.3, 3. 导入

oracle简单使用

连接方式 Oracle简单使用 Emp数据表 1.sqlplus命令 1)Scott用户登录:Sqlplus scott/tiger查询emp表的全部内容Select * from emp;问题:(1)表格的显示格式混乱(2)所有表格都有标题行设置每行显示的数据长度:set linesize 300;设置每次显示胡行数:set pagesize 30; 再执行 select * from emp: 命令格式:col job for a8; 列空格设定8 Col job for a8:select

oracle 简单入门

1.什么是主键? 答:在数据表中能够唯一和完整标识数据列和行的组合,只能有一个且不能为空. 2.什么是外键? 答:在一个表中存在另一个表的外键. 3.存储过程和触发器的区别 答:触发器和存储过程非常相似,触发器也是sql语句集,两者唯一的区别就是触发器不能使用execute语句,而是在用户执行Transact-SQL语句时自动触发执行. 触发器是在一个修改了指定表中的数据执行的存储过程.通常通过创建触发器来强制实现不同表中的逻辑相关数据的引用完整性和一致性.由于用户不能绕过触发器,所以可以使用它

Oracle简单学习笔记

创建用户 1 CREATE USER username identified by password;//这是最简单的用户创建SQL语句. 2 CREATE USER username identified by password default tablespace users temporary tablespace temp;//增加指定表空间的SQL语句. 分配用户权限 1 grant 权限/角色 to 用户;//把权限或角色的权限 分配给 用户. 2 revoke 权限/角色 from

oracle 简单查询

数据查询是用SELECT命令从数据库的表中提取信息. 语法结构:简单查询 SELECT *|列名|表达式 FROM 表名 WHERE 条件 ORDER BY 列名 语法解析: *表示表中的所有列. 列名可以选择若干个表中的列名,各个列表中间用逗号分隔. 表达式可以是列名.函数.常数等组成的表达式. WHERE子句是查询的条件. ORDER BY 要求在查询的结果中排序,默认是升序. Oracle中可以把查询的结果根据结果集中的表结构和数据形成一张新表. 语法结构:根据结果集创建表 CREATE

08.17《jsp》——html+css+js+jsp+servlet+oracle简单项目练习

16,17号,两天时间,结束了JSP的学习,开始了项目的实践学习 第一步是最简单的添加 在这之中,对于数据库的链接,间接的展开了jdbc的复习,在其中由于数据库和老师所给的教材不相符,所以停顿在链接数据的时间很长,在一遍遍的修改ORA-12505错误没有结果的时候,使用最笨的办法重新安装了一个ORACLE数据库,将其命名与老师的同名,这样解决了数据库的链接失败问题. 第二步是查找操作 有了第一次的流程,所以这次速度快了一些,在一边完成查找操作的同时一边熟悉着流程,熟悉着数据流向的过程,由页面 -

Oracle简单学习

最近一段时间重温了oracle关于存储过程和oracle包以及function中的定义, 先看一下要用的表: devices(id number, name varchar2, age number) groups(id number, devicesid number, name varchar2, content varchar2) 在oracle中建立如下的package和package bodies, 下面给出里面具体的内容: 首先是packges下面的devices_pkg内容: 定义