- 浏览: 165920 次
- 性别:
- 来自: 济南
-
文章分类
- 全部博客 (103)
- ORA-19815: WARNING: db_recovery_file_dest_size of 2147483648 bytes is 100.00% used (1)
- SUN-solaris (1)
- liunx------suse平台 (1)
- alter system switch logfile和alter system archive log current的区别 (1)
- http://shanchao7932297.blog.163.com/blog/static/1363624201131534318387/ (1)
- http://linuxkeep.blog.51cto.com/1010009/634472 (1)
- http://download.chinaunix.net/download.php?id=24294&ResourceID=12275 (1)
- http://zhumeng8337797.blog.163.com/blog/static/100768914201182810548991/ (1)
- 安装mysql,在./configure时出现错误:error: No curses/termcap library found的解决办法 (1)
- http://www.docin.com/p-79019394.html (1)
- http://wenku.it168.com/d_000410287.shtml (1)
- http://www.db2china.net/club/thread-24311-1-1.html (1)
- Download DB2 Fix Packs by version for DB2 for Linux (1)
- UNIX and Windows (1)
- http://www.db2china.net/club/viewthread.php?tid=26443 (1)
- http://beijing.qianpin.com/goods/103761.html?showGoods=true&abacusoutsid=api_fee_360_103761 (1)
- http://www.db2china.net/home/space.php?uid=23781&do=blog&id=18855 (1)
- http://www.db2china.net/club/search.php?searchid=19&orderby=lastpost&ascdesc=desc&searchsubmit=yes (0)
- http://www.db2china.net/home/space.php?uid=23781&do=blog&id=18853 (1)
- http://www.db2china.net/home/space.php?uid=26946&do=blog&id=13104 (1)
- 北京社保卡缴费记录查询网站 (1)
- http://blog.sina.com.cn/s/blog_58dc4b630100fesx.html (0)
- http://www.db2china.net/home/space.php?uid=26946&do=blog&id=14419 (1)
- itpub数据库猎头招聘 (0)
- http://www.itpub.net/thread-1128353-1-1.html (1)
- aix (0)
- nub的使用 (0)
最新评论
Oracle基础知识
Oracle数据的开启
1、 安装成功后进入DOS界面操作win键假R 如下图
2、 输入cmd进入控制台如图
3、 输入sqlplus 之后输入用户名密码启动Oracle服务。
此时进入了Oracle界面。
Oracle DOS密码的修改
当忘记密码时,可以采用
sqlplus sys/aaa as sysdba;--以数据库管理员的身份登录. 如果在本机登录
密码可以随意输入。
修改密码:
//修改system用户的密码是system
alter user system identified by root;
注:alter user identified by 都是关键字
Oracle DOS切换用户操作
A、先退出 再登陆
exit;退出。
1、登录命令 sqlplus system/system 直接登录
2、sqlplus
--提示输入用户名
--提示输入密码
B、也可以不退出直接在sql>操作中采用 conn scott/tiger conn/用户名/密码切换用户
注意:登录的时候没有分号结束。
Oracle 中的表是按照用户进行分类的
sys 超级用户(权限最高)
system 数据库管理员(执行大部分管理操作)
自定用户 测试用户
Oracle简单入门命令
select * from tabs;---查询当前用户下有哪些表(多查询出系统表);
select table_name from user_tables; ---查询当前用户下的所有表的名称。
desc 表名 ---查看表有哪些列(表的结构)
客户端工具安装;
远程数据库的连接
--前提: 1、在客户端程序必须安装oracle客户端程序
2、服务器端的防火墙必须关闭因为oracle采用的是TCP/IP协议的。
3、需要添加全局配置,修改配置文件
D:/DbOracle/app/oracle/product/10.2.0/server/NETWORK/ADMIN
您的oracle 安装的目录
在network/admin/找到tnsnames.ora配置文件内容如下:
XE =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 朱磊-PC)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = XE)
)
)
EXTPROC_CONNECTION_DATA =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC_FOR_XE))
)
(CONNECT_DATA =
(SID = PLSExtProc)
(PRESENTATION = RO)
)
)
ORACLR_CONNECTION_DATA =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC_FOR_XE))
)
(CONNECT_DATA =
(SID = CLRExtProc)
(PRESENTATION = RO)
)
)
XE是默认的全局名称PROTOCOL = TCP 协议
HOST = PC-201009100931 本机的名称
PORT = 1521 oralce的端口号
如果需要采用远程连接需要配置一个全局的连接属性
teacher =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = XE)
)
)
teacher是随意起的全局名称注意:名称不能重复
HOST = 192.168.51.42 是远程局连接的IP地址
PORT = 1521是远程连接的端口号.必须一致。
SERVICE_NAME = zhu 是远程连接服务的名称.必须一致。
备注:可以到服务端的tnsnames.ora文件中查找PORT与SERVICE_NAME。
注意:以上配置teacher之前不能有空格否则会有异常信息。
当远程客户连接服务器时,服务器端的OracleXETNSListener的监听必须启动
打开方式---管理工具--服务中---查找OracleXETNSListener并启动程序。
--sqlplus远程连接命令
sqlplus 服务器端的用户名/密码@全局数据库名称
sqlplus 服务器端的用户名/密码@teacher;即可。
用户操作命令
创建用户
SQL> conn system/root
已连接。
SQL> create user zhulei identified by zhulei;
用户已创建。
用户授权
SQL> grant create session,create table,resource to zhulei;
授权成功。
SQL> select * from session_privs; 查看所有的权限名字
1、 grant create session to zhulei;//授予zhulei用户创建session的权限,即登陆权限
2、 grant unlimited session to zhulei;//授予zhulei用户使用表空间的权限
3、 grant create table to zhulei;//授予创建表的权限
4、 grante drop table to zhulei;//授予删除表的权限
5、 grant insert table to zhulei;//插入表的权限
6、 grant update table to zhulei;//修改表的权限
7、 grant all to public;//这条比较重要,授予所有权限(all)给所有用户(public)
oralce对权限管理比较严谨,普通用户之间也是默认不能互相访问的,需要互相授权
/*oralce对权限管理比较严谨,普通用户之间也是默认不能互相访问的*/
grant select on tablename to zhulei;//授予zhulei用户查看指定表的权限
grant drop on tablename to zhulei;//授予删除表的权限
grant insert on tablename to zhulei;//授予插入的权限
grant update on tablename to zhulei;//授予修改表的权限
grant insert(id) on tablename to zhulei;
grant update(id) on tablename to zhulei;//授予对指定表特定字段的插入和修改权限,注意,只能是insert和update
grant alert all table to zhulei;//授予zhulei用户alert任意表的权限
撤销权限
基本语法同grant,关键字为revoke
查看权限
select * from user_sys_privs;//查看当前用户所有权限
select * from user_tab_privs;//查看所用用户对表的权限
操作表的用户的表
/*需要在表名前加上用户名,如下*/
select * from zhulei.tablename
权限传递
grant alert table on tablename to zhulei with admin option;//关键字 with admin option
grant alert table on tablename to zhulei with grant option;//关键字 with grant option效果和admin类似
角色
角色即权限的集合,可以把一个角色授予给用户
create role myrole;//创建角色
grant create session to myrole;//将创建session的权限授予myrole
grant myrole to zhulei;//授予zhulei用户myrole的角色
drop role myrole;删除角色
/*但是有些权限是不能授予给角色的,比如unlimited tablespace和any关键字*/
删除用户
SQL> drop user zhulei;
用户已删除。
登录简单总结
• SQL Plus 登录的几种不同方式
• sqlplus 根据提示输入用户名、密码
• sqlplus 用户名/密码 (本机登录)
• sqlplus 用户名/密码@网络服务名 (远程登录)
• sqlplus / as sysdba (以sysdba身份登录,用户实际为sys)
导入外部文件
注:空格否则会出现如下错误:
SQL> start C:/a a a/emp.sql;
Error reading file
SQL> start c:/emp.sql
SQL Plus常见的命令
l conn 切换连接用户
l desc 显示表结构
l host 执行操作系统命令
l start 执行文件系统SQL语句
l exit 退出
l col 格式化输出
l / 执行最近一条SQL或新定义过程
l startup 启动数据库实例 (DBA)
l shutdown 关闭数据库实例 (DBA)
(一) 数据类型:
数据是信息数字表现形式,信息的加工处理是以大量的结构化数据为载体进行的,数据库管理系统的核心是数据库,数据库的主要对象是表,表是结构化数据存储的地方.
用户自定义的数据类型
内置的数据类型
1. 字符型
字符数据类型可以用于声明包含了多个字母数字数据的字段。
a) char:用于存储固定长度的字符,一旦声明长度固定(不论你存储的实际大小,但是大小绝对不能大于声明的长度)长度不足时,采用空格补充。1B的默认大小,最大尺寸为2000B。
b) Nchar与char的解析是一样的不过,ncarh存储的是Unicode字符数据。
2. 可变长度的字符类型
a) varchar与char类似,但是它是用于存储可变的字符串,而char用于存储固定的字符串。
b) Nvarchar与varchar解析是一样的,不过nvarchar用于存储的数据位双字节的数据。
c) Varchar2存储可变的字符串,当存储的字符串小于Varchar2定义的数据类型长度,不以空格补充。同时varchar2 是把字符的长度和汉字的长度一样,都是2,还有最长也只有4000
d) 日期类型:
date 短日期格式(1990-10-10); Timestamp长日期格式(1990-10-10 10:10:10)
e) 数字型:
Number(2),代表:声明一个2位数字的整数。
Number(3,2)代表:声明为3数字位,并且小数后有2位。
f) 文本型-àlob数据类型:
Blob:可以存储图像,音频文件及视频等文件。
Clob:字符格式的大型对象,oracle数据àunicode格式的编码
Bfile:用于存储二进制格式的文件。
-rowid 伪劣类型:用于在oracle内部保存表中的每条记录的物理地址。
(二) Sql语句:
SQL是structured Query Language(结构化查询语言)的缩写。可以使用sql语句建立或删除数据库的对象,插入,修改和更新数据库中的数据,并且可以对数据库执行各种日常管理的操作。它是所有关系数据库管理系统的标准语言.换句话说使用sql可以对所有的关系数据库进行操作。
SQL按照功能分类
1、 数据库定义语句
DDL(Data Definition Language):用于创建、修改、删除数据库对象。
2、 数据库操作语句
DML(Data Manipulation Language)用于:查询,添加修改或删除存在数据库对象中的数据。
3、 数据库控制语句DCL
DCL(Data Control Language)用于控制访问数据库中特定对象的用户、grant revoke
Oracle系统中经过对Sql语言扩展被称为PL/SQL语言。
查询语句
• 基本的sql查询语句
SELECT *|{[DISTINCT] column|expression [alias],...}
FROM table;
SQL> select * from emp;//查询所有的字段信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp;//查询所有
SQL> select empno from emp;//查询部分字段
SQL> select empno "员工编号" from emp;//采用别名查询
SQL> select empno as "员工编号" from emp;//采用别名查询等效于上面的效果
SQL> select distinct(hiredate) from emp;//查询所有员工的入职日期并且去掉重复的日期
SQL> select sal+comm from emp;//注意:包含空值的数学表达式求出的结果为空值
SQL> select empno||ename from emp;//||连接符把empno与ename作为一个字段显示
SQL> select empno||ename as "员工编号和员工姓名" from emp;//效果同上
SQL> select '员工的编号是'||empno from emp;//字符的链接
SQL> select '姓名为'||ename||'员工,所在的部门是:'||deptno as "新列" from emp;//字段的链接包号字符连接
SQL> select distinct(deptno) from emp;//查询去掉重复行的员工部门编号
• 条件查询
SELECT *|{[DISTINCT] column|expression [alias],...}
FROM table
[WHERE condition(s)];
Condition(s)要使用到比较运算符常用的比较运算符如下:
操作符
含义
=
等于
>
大于
>=
大于等于
<
小于
<=
小于等于
<>
不等于等效于!=
其它操作
And 逻辑运算 逻辑与
Or 逻辑运算 逻辑或
Not 逻辑运算 逻辑否
Between 起始值 and 结束值:使用 BETWEEN 运算来显示在一个区间内的值包含(起始结束值)
In:使用 IN运算显示列表中的值。 In(,,,)相当于一个集合,只要出现集合中匹配的就显示
Like:
l 使用 LIKE 运算选择类似的值
l 选择条件可以包含字符或数字:
• % 代表零个或多个字符(任意个字符)。
• _ 代表一个字符。
Escape:
回避特殊符号的:使用转义符。例如:将[%]转为[/%]、[_]转为[/_],然后再加上[ESCAPE ‘/’] 即可
Null:
使用 IS (NOT) NULL 判断空值。
//查询部门号为10的员工信息 部门为整数类型
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno=10;
//查询职位号为MANAGER的员工信息 岗位的类型为字符类型
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where job='MANAGER';
//查询部门号为10并且员工的职位为MANAGER的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where job='MANAGER' and deptno=10;
注意:
l 字符和日期要包含在单引号中。
l 字符大小写敏感,日期格式敏感。
l 默认的日期格式是 DD-MON-RR。
//查询部门号大于10的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno>10;
//查询薪水大于等于3000的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>=3000;
//查询薪水不等于3000的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal<>3000;
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal !=3000;
//查询薪水大于2000并且小于3000的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>2000 and sal<3000;
//查询薪水大于等于2000并且小于等于3000的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal between 1600 and 3000;
//等效于
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>=1600 and sal<=3000;
//查询部门号位10,20的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno in(10,20);
//注意:相当于如下操作:
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno =10 or deptno=20;
//查询员工名称以S开头的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like 'S%';
//查询员工名称以S结尾的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%S';
//查询员工名称第三个字符为N的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '__N%';
//查询员工名称中含有N的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%N%';
//查询员工名称中倒数第二个字符为%的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%/%_'escape'/';
//查询员工名称总含有%的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%/%%'escape'/';
//查询奖金为null的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where comm is null;
//查询奖金非null的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where comm is not null;
优先级表格:
优先级
1
算术运算
2
连接符
3
比较符
4
Is not null like not in
5
Not between
6
not
7
and
8
Or
备注:可以采用括号改变优先级
• Order by 子句:
使用 ORDER BY 子句排序
ASC(ascend): 升序
DESC(descend): 降序
注:ORDER BY 子句在SELECT语句的结尾。
//查询员工信息按照部门的编号进行升序排列 默认的是 asc
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno;
//查询员工信息按照部门的编号进行降序排列 使用desc
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno desc;
//查询部门为20的员工信息并按照员工的编号进行升序排列
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno=20 order by empno asc;
备注:可以与条件语句结合使用但order by子句放在最后
//查询员工信息并按照员工的部门编号升序并且编号进行降序排列
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno asc,empno desc;
备注:理解思路:首先查询员工信息按照部门的编号进行升序,然后每个部门中的员工按照员工的编号进行降序排列
Sql--plus函数
字符串函数是oracle使用最广泛的一种函数.
LOWER:小写
UPPER:大写
INITCAP:首字母大写
CONCAT:连接
SUBSTR:截取 (参数,开始,数目)
LENGTH:返回字符串的长度
INSTR:(参数,字母) 返回字母出现的位置
LPAD:(参数,长度,在前补齐参数字母)
RPAD:(参数,长度,在后补齐参数字母)
TRIM :
REPLACE:(参数,参数[,参数]):第一个参数操作数,第二是要查找的字符,第三个是替换的字符,如果没有第三个就删除查找的字符。
//查询名称为scott的员工信息(不区分大小写)
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where lower(ename)='scott';
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where upper(ename)='SCOTT';
//查询员工信息把员工名称与工作连接在一起
SQL> select empno,concat(ename,job),mgr,hiredate,sal,comm,deptno from emp;
//查询员工信息把员工名称与工作连接在一起
SQL> select empno,concat(ename||'is work:',job),mgr,hiredate,sal,comm,deptno from emp;
//查询员工名称中含有O字符的位置index索引值
SQL> select empno,instr(ename,'O'),job,mgr,hiredate,sal,comm,deptno from emp;
//查询员工名称中含有O字符的位置并且求出了员工名称字符长度
SQL> select empno,instr(ename,'O'),length(ename),job,mgr,hiredate,sal,comm,deptno from emp;
//在查询上面结果中过滤出员工工作从第三字母开始为ERK员工信息
SQL> select empno,instr(ename,'O'),length(ename),job,mgr,hiredate,sal,comm,deptno from emp where substr(job,3)='ERK';
备注:当含有两个参数的时候,从开始位置直接到参数结束的结束为止
//在效果同上的同时指明了截取个数为3
SQL> select empno,instr(ename,'O'),length(ename),job,mgr,hiredate,sal,comm,deptno from emp where substr(job,3,3)='ERK';
//查询员工信息 薪资是10位位数不够在左部分补*填充
SQL> select empno,ename,job,mgr,hiredate,LPAD(sal,10,'*'),comm,deptno from emp;
//查询员工信息 薪资是10位位数不够在右部分补*填充
SQL> select empno,ename,job,mgr,hiredate,RPAD(sal,10,'*'),comm,deptno from emp;
//查询员工信息 把员工名称中含有S字符去除掉
SQL> select empno,TRIM('S' from ename),job,mgr,hiredate,10,comm,deptno from emp;
等效于:
SQL> select empno,TRIM( both 'S' from ename),job,mgr,hiredate,10,comm,deptno from emp;
//查询员工信息 把员工名称中前面有S字符去除掉
SQL> select empno,TRIM( Leading 'S' from ename),job,mgr,hiredate,10,comm,deptno from emp;
//等效于
SQL> select empno,LTRIM( ename,'S'),job,mgr,hiredate,10,comm,deptno from emp;
//查询员工信息 把员工名称中后面有S字符去除掉
SQL> select empno,TRIM( trailing 'S' from ename),job,mgr,hiredate,10,comm,deptno from emp;
等效于:
SQL> select empno,RTRIM( ename,'S'),job,mgr,hiredate,10,comm,deptno from emp;
插入语句:
1、 向表中插入一条新的(全字段)记录
SQL> insert into emp(empno,ename,job,mgr,hiredate,sal,comm,deptno) values(1111,'test','test','7369',to_date('1992-12-12','yyyy-mm-dd'),100,100,20);
1 row inserted
或者写成
SQL> insert into emp values(2222,'test','test','7369',to_date('1992-12-12','yyyy-mm-dd'),100,100,20);
1 row inserted
都过查询即可看到结果
SQL> select * from emp;
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7369 SMITH CLERK 7902 1980-12-17 800.00 20
……….//省略部分
1111 test test 7369 1992-12-12 100.00 100.00 20
2222 test test 7369 1992-12-12 100.00 100.00 20
2、 向表中插入一条新的(部分字段)记录
SQL>insert into emp(empno,ename,hiredate,deptno) values(3333,'test',to_date('1992-12-12','yyyy-mm-dd'),30);
1 row inserted
注意:在插入操作的时候如果有关联,一定要插入相应关联的字段的值.
备注:插入之后都需要手动的提交 commit;
SQL> commit;
Commit complete
1、 安装成功后进入DOS界面操作win键假R 如下图
2、 输入cmd进入控制台如图
3、 输入sqlplus 之后输入用户名密码启动Oracle服务。
此时进入了Oracle界面。
Oracle DOS密码的修改
当忘记密码时,可以采用
sqlplus sys/aaa as sysdba;--以数据库管理员的身份登录. 如果在本机登录
密码可以随意输入。
修改密码:
//修改system用户的密码是system
alter user system identified by root;
注:alter user identified by 都是关键字
Oracle DOS切换用户操作
A、先退出 再登陆
exit;退出。
1、登录命令 sqlplus system/system 直接登录
2、sqlplus
--提示输入用户名
--提示输入密码
B、也可以不退出直接在sql>操作中采用 conn scott/tiger conn/用户名/密码切换用户
注意:登录的时候没有分号结束。
Oracle 中的表是按照用户进行分类的
sys 超级用户(权限最高)
system 数据库管理员(执行大部分管理操作)
自定用户 测试用户
Oracle简单入门命令
select * from tabs;---查询当前用户下有哪些表(多查询出系统表);
select table_name from user_tables; ---查询当前用户下的所有表的名称。
desc 表名 ---查看表有哪些列(表的结构)
客户端工具安装;
远程数据库的连接
--前提: 1、在客户端程序必须安装oracle客户端程序
2、服务器端的防火墙必须关闭因为oracle采用的是TCP/IP协议的。
3、需要添加全局配置,修改配置文件
D:/DbOracle/app/oracle/product/10.2.0/server/NETWORK/ADMIN
您的oracle 安装的目录
在network/admin/找到tnsnames.ora配置文件内容如下:
XE =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 朱磊-PC)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = XE)
)
)
EXTPROC_CONNECTION_DATA =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC_FOR_XE))
)
(CONNECT_DATA =
(SID = PLSExtProc)
(PRESENTATION = RO)
)
)
ORACLR_CONNECTION_DATA =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC_FOR_XE))
)
(CONNECT_DATA =
(SID = CLRExtProc)
(PRESENTATION = RO)
)
)
XE是默认的全局名称PROTOCOL = TCP 协议
HOST = PC-201009100931 本机的名称
PORT = 1521 oralce的端口号
如果需要采用远程连接需要配置一个全局的连接属性
teacher =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = XE)
)
)
teacher是随意起的全局名称注意:名称不能重复
HOST = 192.168.51.42 是远程局连接的IP地址
PORT = 1521是远程连接的端口号.必须一致。
SERVICE_NAME = zhu 是远程连接服务的名称.必须一致。
备注:可以到服务端的tnsnames.ora文件中查找PORT与SERVICE_NAME。
注意:以上配置teacher之前不能有空格否则会有异常信息。
当远程客户连接服务器时,服务器端的OracleXETNSListener的监听必须启动
打开方式---管理工具--服务中---查找OracleXETNSListener并启动程序。
--sqlplus远程连接命令
sqlplus 服务器端的用户名/密码@全局数据库名称
sqlplus 服务器端的用户名/密码@teacher;即可。
用户操作命令
创建用户
SQL> conn system/root
已连接。
SQL> create user zhulei identified by zhulei;
用户已创建。
用户授权
SQL> grant create session,create table,resource to zhulei;
授权成功。
SQL> select * from session_privs; 查看所有的权限名字
1、 grant create session to zhulei;//授予zhulei用户创建session的权限,即登陆权限
2、 grant unlimited session to zhulei;//授予zhulei用户使用表空间的权限
3、 grant create table to zhulei;//授予创建表的权限
4、 grante drop table to zhulei;//授予删除表的权限
5、 grant insert table to zhulei;//插入表的权限
6、 grant update table to zhulei;//修改表的权限
7、 grant all to public;//这条比较重要,授予所有权限(all)给所有用户(public)
oralce对权限管理比较严谨,普通用户之间也是默认不能互相访问的,需要互相授权
/*oralce对权限管理比较严谨,普通用户之间也是默认不能互相访问的*/
grant select on tablename to zhulei;//授予zhulei用户查看指定表的权限
grant drop on tablename to zhulei;//授予删除表的权限
grant insert on tablename to zhulei;//授予插入的权限
grant update on tablename to zhulei;//授予修改表的权限
grant insert(id) on tablename to zhulei;
grant update(id) on tablename to zhulei;//授予对指定表特定字段的插入和修改权限,注意,只能是insert和update
grant alert all table to zhulei;//授予zhulei用户alert任意表的权限
撤销权限
基本语法同grant,关键字为revoke
查看权限
select * from user_sys_privs;//查看当前用户所有权限
select * from user_tab_privs;//查看所用用户对表的权限
操作表的用户的表
/*需要在表名前加上用户名,如下*/
select * from zhulei.tablename
权限传递
grant alert table on tablename to zhulei with admin option;//关键字 with admin option
grant alert table on tablename to zhulei with grant option;//关键字 with grant option效果和admin类似
角色
角色即权限的集合,可以把一个角色授予给用户
create role myrole;//创建角色
grant create session to myrole;//将创建session的权限授予myrole
grant myrole to zhulei;//授予zhulei用户myrole的角色
drop role myrole;删除角色
/*但是有些权限是不能授予给角色的,比如unlimited tablespace和any关键字*/
删除用户
SQL> drop user zhulei;
用户已删除。
登录简单总结
• SQL Plus 登录的几种不同方式
• sqlplus 根据提示输入用户名、密码
• sqlplus 用户名/密码 (本机登录)
• sqlplus 用户名/密码@网络服务名 (远程登录)
• sqlplus / as sysdba (以sysdba身份登录,用户实际为sys)
导入外部文件
注:空格否则会出现如下错误:
SQL> start C:/a a a/emp.sql;
Error reading file
SQL> start c:/emp.sql
SQL Plus常见的命令
l conn 切换连接用户
l desc 显示表结构
l host 执行操作系统命令
l start 执行文件系统SQL语句
l exit 退出
l col 格式化输出
l / 执行最近一条SQL或新定义过程
l startup 启动数据库实例 (DBA)
l shutdown 关闭数据库实例 (DBA)
(一) 数据类型:
数据是信息数字表现形式,信息的加工处理是以大量的结构化数据为载体进行的,数据库管理系统的核心是数据库,数据库的主要对象是表,表是结构化数据存储的地方.
用户自定义的数据类型
内置的数据类型
1. 字符型
字符数据类型可以用于声明包含了多个字母数字数据的字段。
a) char:用于存储固定长度的字符,一旦声明长度固定(不论你存储的实际大小,但是大小绝对不能大于声明的长度)长度不足时,采用空格补充。1B的默认大小,最大尺寸为2000B。
b) Nchar与char的解析是一样的不过,ncarh存储的是Unicode字符数据。
2. 可变长度的字符类型
a) varchar与char类似,但是它是用于存储可变的字符串,而char用于存储固定的字符串。
b) Nvarchar与varchar解析是一样的,不过nvarchar用于存储的数据位双字节的数据。
c) Varchar2存储可变的字符串,当存储的字符串小于Varchar2定义的数据类型长度,不以空格补充。同时varchar2 是把字符的长度和汉字的长度一样,都是2,还有最长也只有4000
d) 日期类型:
date 短日期格式(1990-10-10); Timestamp长日期格式(1990-10-10 10:10:10)
e) 数字型:
Number(2),代表:声明一个2位数字的整数。
Number(3,2)代表:声明为3数字位,并且小数后有2位。
f) 文本型-àlob数据类型:
Blob:可以存储图像,音频文件及视频等文件。
Clob:字符格式的大型对象,oracle数据àunicode格式的编码
Bfile:用于存储二进制格式的文件。
-rowid 伪劣类型:用于在oracle内部保存表中的每条记录的物理地址。
(二) Sql语句:
SQL是structured Query Language(结构化查询语言)的缩写。可以使用sql语句建立或删除数据库的对象,插入,修改和更新数据库中的数据,并且可以对数据库执行各种日常管理的操作。它是所有关系数据库管理系统的标准语言.换句话说使用sql可以对所有的关系数据库进行操作。
SQL按照功能分类
1、 数据库定义语句
DDL(Data Definition Language):用于创建、修改、删除数据库对象。
2、 数据库操作语句
DML(Data Manipulation Language)用于:查询,添加修改或删除存在数据库对象中的数据。
3、 数据库控制语句DCL
DCL(Data Control Language)用于控制访问数据库中特定对象的用户、grant revoke
Oracle系统中经过对Sql语言扩展被称为PL/SQL语言。
查询语句
• 基本的sql查询语句
SELECT *|{[DISTINCT] column|expression [alias],...}
FROM table;
SQL> select * from emp;//查询所有的字段信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp;//查询所有
SQL> select empno from emp;//查询部分字段
SQL> select empno "员工编号" from emp;//采用别名查询
SQL> select empno as "员工编号" from emp;//采用别名查询等效于上面的效果
SQL> select distinct(hiredate) from emp;//查询所有员工的入职日期并且去掉重复的日期
SQL> select sal+comm from emp;//注意:包含空值的数学表达式求出的结果为空值
SQL> select empno||ename from emp;//||连接符把empno与ename作为一个字段显示
SQL> select empno||ename as "员工编号和员工姓名" from emp;//效果同上
SQL> select '员工的编号是'||empno from emp;//字符的链接
SQL> select '姓名为'||ename||'员工,所在的部门是:'||deptno as "新列" from emp;//字段的链接包号字符连接
SQL> select distinct(deptno) from emp;//查询去掉重复行的员工部门编号
• 条件查询
SELECT *|{[DISTINCT] column|expression [alias],...}
FROM table
[WHERE condition(s)];
Condition(s)要使用到比较运算符常用的比较运算符如下:
操作符
含义
=
等于
>
大于
>=
大于等于
<
小于
<=
小于等于
<>
不等于等效于!=
其它操作
And 逻辑运算 逻辑与
Or 逻辑运算 逻辑或
Not 逻辑运算 逻辑否
Between 起始值 and 结束值:使用 BETWEEN 运算来显示在一个区间内的值包含(起始结束值)
In:使用 IN运算显示列表中的值。 In(,,,)相当于一个集合,只要出现集合中匹配的就显示
Like:
l 使用 LIKE 运算选择类似的值
l 选择条件可以包含字符或数字:
• % 代表零个或多个字符(任意个字符)。
• _ 代表一个字符。
Escape:
回避特殊符号的:使用转义符。例如:将[%]转为[/%]、[_]转为[/_],然后再加上[ESCAPE ‘/’] 即可
Null:
使用 IS (NOT) NULL 判断空值。
//查询部门号为10的员工信息 部门为整数类型
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno=10;
//查询职位号为MANAGER的员工信息 岗位的类型为字符类型
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where job='MANAGER';
//查询部门号为10并且员工的职位为MANAGER的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where job='MANAGER' and deptno=10;
注意:
l 字符和日期要包含在单引号中。
l 字符大小写敏感,日期格式敏感。
l 默认的日期格式是 DD-MON-RR。
//查询部门号大于10的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno>10;
//查询薪水大于等于3000的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>=3000;
//查询薪水不等于3000的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal<>3000;
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal !=3000;
//查询薪水大于2000并且小于3000的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>2000 and sal<3000;
//查询薪水大于等于2000并且小于等于3000的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal between 1600 and 3000;
//等效于
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>=1600 and sal<=3000;
//查询部门号位10,20的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno in(10,20);
//注意:相当于如下操作:
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno =10 or deptno=20;
//查询员工名称以S开头的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like 'S%';
//查询员工名称以S结尾的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%S';
//查询员工名称第三个字符为N的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '__N%';
//查询员工名称中含有N的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%N%';
//查询员工名称中倒数第二个字符为%的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%/%_'escape'/';
//查询员工名称总含有%的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%/%%'escape'/';
//查询奖金为null的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where comm is null;
//查询奖金非null的员工信息
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where comm is not null;
优先级表格:
优先级
1
算术运算
2
连接符
3
比较符
4
Is not null like not in
5
Not between
6
not
7
and
8
Or
备注:可以采用括号改变优先级
• Order by 子句:
使用 ORDER BY 子句排序
ASC(ascend): 升序
DESC(descend): 降序
注:ORDER BY 子句在SELECT语句的结尾。
//查询员工信息按照部门的编号进行升序排列 默认的是 asc
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno;
//查询员工信息按照部门的编号进行降序排列 使用desc
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno desc;
//查询部门为20的员工信息并按照员工的编号进行升序排列
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno=20 order by empno asc;
备注:可以与条件语句结合使用但order by子句放在最后
//查询员工信息并按照员工的部门编号升序并且编号进行降序排列
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno asc,empno desc;
备注:理解思路:首先查询员工信息按照部门的编号进行升序,然后每个部门中的员工按照员工的编号进行降序排列
Sql--plus函数
字符串函数是oracle使用最广泛的一种函数.
LOWER:小写
UPPER:大写
INITCAP:首字母大写
CONCAT:连接
SUBSTR:截取 (参数,开始,数目)
LENGTH:返回字符串的长度
INSTR:(参数,字母) 返回字母出现的位置
LPAD:(参数,长度,在前补齐参数字母)
RPAD:(参数,长度,在后补齐参数字母)
TRIM :
REPLACE:(参数,参数[,参数]):第一个参数操作数,第二是要查找的字符,第三个是替换的字符,如果没有第三个就删除查找的字符。
//查询名称为scott的员工信息(不区分大小写)
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where lower(ename)='scott';
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where upper(ename)='SCOTT';
//查询员工信息把员工名称与工作连接在一起
SQL> select empno,concat(ename,job),mgr,hiredate,sal,comm,deptno from emp;
//查询员工信息把员工名称与工作连接在一起
SQL> select empno,concat(ename||'is work:',job),mgr,hiredate,sal,comm,deptno from emp;
//查询员工名称中含有O字符的位置index索引值
SQL> select empno,instr(ename,'O'),job,mgr,hiredate,sal,comm,deptno from emp;
//查询员工名称中含有O字符的位置并且求出了员工名称字符长度
SQL> select empno,instr(ename,'O'),length(ename),job,mgr,hiredate,sal,comm,deptno from emp;
//在查询上面结果中过滤出员工工作从第三字母开始为ERK员工信息
SQL> select empno,instr(ename,'O'),length(ename),job,mgr,hiredate,sal,comm,deptno from emp where substr(job,3)='ERK';
备注:当含有两个参数的时候,从开始位置直接到参数结束的结束为止
//在效果同上的同时指明了截取个数为3
SQL> select empno,instr(ename,'O'),length(ename),job,mgr,hiredate,sal,comm,deptno from emp where substr(job,3,3)='ERK';
//查询员工信息 薪资是10位位数不够在左部分补*填充
SQL> select empno,ename,job,mgr,hiredate,LPAD(sal,10,'*'),comm,deptno from emp;
//查询员工信息 薪资是10位位数不够在右部分补*填充
SQL> select empno,ename,job,mgr,hiredate,RPAD(sal,10,'*'),comm,deptno from emp;
//查询员工信息 把员工名称中含有S字符去除掉
SQL> select empno,TRIM('S' from ename),job,mgr,hiredate,10,comm,deptno from emp;
等效于:
SQL> select empno,TRIM( both 'S' from ename),job,mgr,hiredate,10,comm,deptno from emp;
//查询员工信息 把员工名称中前面有S字符去除掉
SQL> select empno,TRIM( Leading 'S' from ename),job,mgr,hiredate,10,comm,deptno from emp;
//等效于
SQL> select empno,LTRIM( ename,'S'),job,mgr,hiredate,10,comm,deptno from emp;
//查询员工信息 把员工名称中后面有S字符去除掉
SQL> select empno,TRIM( trailing 'S' from ename),job,mgr,hiredate,10,comm,deptno from emp;
等效于:
SQL> select empno,RTRIM( ename,'S'),job,mgr,hiredate,10,comm,deptno from emp;
插入语句:
1、 向表中插入一条新的(全字段)记录
SQL> insert into emp(empno,ename,job,mgr,hiredate,sal,comm,deptno) values(1111,'test','test','7369',to_date('1992-12-12','yyyy-mm-dd'),100,100,20);
1 row inserted
或者写成
SQL> insert into emp values(2222,'test','test','7369',to_date('1992-12-12','yyyy-mm-dd'),100,100,20);
1 row inserted
都过查询即可看到结果
SQL> select * from emp;
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7369 SMITH CLERK 7902 1980-12-17 800.00 20
……….//省略部分
1111 test test 7369 1992-12-12 100.00 100.00 20
2222 test test 7369 1992-12-12 100.00 100.00 20
2、 向表中插入一条新的(部分字段)记录
SQL>insert into emp(empno,ename,hiredate,deptno) values(3333,'test',to_date('1992-12-12','yyyy-mm-dd'),30);
1 row inserted
注意:在插入操作的时候如果有关联,一定要插入相应关联的字段的值.
备注:插入之后都需要手动的提交 commit;
SQL> commit;
Commit complete
相关推荐
对于初学者来说,掌握Oracle基础知识是进入数据库领域的第一步。本文将深入浅出地介绍Oracle数据库的一些核心概念和基本操作,帮助你快速入门。 一、Oracle数据库系统概述 Oracle数据库是由美国Oracle公司开发的,...
这个"oracle基础知识考试题_答案.zip"压缩包文件包含了关于Oracle数据库的基础知识学习材料,特别是针对初学者或者准备Oracle相关资格考试的人员。 首先,Oracle数据库的核心概念包括SQL(结构化查询语言)的使用,...
本资料“oracle基础知识回顾与练习.zip”是针对Oracle数据库的基础知识进行整理,采用纯SQL语句的形式,适合初学者及需要巩固基础的用户进行学习和实践。 1. SQL基础 SQL(Structured Query Language)是用于管理...
本文将深入探讨Oracle基础知识,包括其架构、安装、数据类型、SQL语句、表空间管理以及备份与恢复策略。 一、Oracle数据库架构 Oracle数据库采用客户/服务器(Client/Server)模式,由多个组件构成。主要包括数据库...
以下是一些Oracle基础知识的详细解释: 1. SQL*Plus工具:这是Oracle数据库管理员(DBA)和开发人员常用的命令行界面,用于执行SQL查询和其他数据库操作。`set linesize` 和 `set pagesize` 用于调整输出的行宽和每...
以下是对Oracle基础知识的详细解析: **1. Oracle数据库概述** Oracle数据库是一个关系型数据库管理系统(RDBMS),它以数据表的形式存储和管理数据,每个表由列定义,数据以行的形式存储。Oracle 8i及以上版本还...
以下将详细讲解Oracle基础知识,包括数据库管理、表的创建与维护、SQL查询技巧、权限管理以及PL/SQL编程等方面。 1. **Oracle数据库优势** Oracle数据库因其高性能、高可用性和安全性而受到青睐。它支持大规模并发...
Oracle基础知识 Oracle基础知识概述 Oracle是世界第二大软件公司,提供了数据库、电子商务套件、ERP、财务产品、开发工具培训认证等产品。Oracle服务器是一个关系数据库管理系统,提供开放、全面、完整的信息管理...
Oracle基础知识概述 Oracle基础知识概述是一份关于Oracle数据库的详细介绍,涵盖了数据库概念、Oracle发展史、Oracle基础知识、安装和卸载等方面的内容。 一、数据库概念 数据库是一个集合了大量数据的仓库,具有...
Oracle基础知识涵盖了从数据库系统的基本概念到具体的操作方法。Oracle,由甲骨文公司开发,是全球领先的数据库管理系统,尤其在信息管理和服务器技术方面具有显著地位。Oracle产品线广泛,包括服务器和工具、应用...
ORACLE基础知识及故障定位 学校oracle基础知识,包含所有orcale的数据库知识,以及常见问题解决思路,解决方案,问题怎么定位。
Oracle数据库是全球最广泛使用的...以上就是Oracle基础知识的一些关键点,这些内容可能会出现在"Oracle基础知识测试"中。通过学习和掌握这些知识,可以有效地管理和操作Oracle数据库,满足企业对数据存储和处理的需求。
一、Oracle基础知识 Oracle数据库系统基于SQL语言,提供了一个高度可扩展、安全且可靠的平台。它的核心组成部分包括服务器进程、客户端进程、控制文件、数据文件、重做日志文件和系统全局区(SGA)等。SGA是Oracle...
这只是Oracle基础知识的冰山一角,随着学习的深入,你将了解更多关于索引、触发器、存储过程、备份与恢复、性能调优等方面的知识。Oracle数据库是一个庞大且复杂的系统,但通过持续学习和实践,你可以逐步掌握并利用...
在“Oracle基础知识第三讲”中,我们将深入理解Oracle数据库的一些核心概念,包括如何启停Enterprise Manager Database Control、Oracle Listener以及数据库本身,以及数据库的日志文件和初始化参数文件的重要性。...
这份"Oracle基础知识培训.ppt"涵盖了Oracle数据库的基础概念、架构、存储结构、启动与关闭、监听器配置、服务器模式、用户管理、权限管理、表空间管理和SQL执行优化等关键知识点。 1. **Oracle体系结构** - **数据...