【从零开始学习Oracle数据库】(1)建表与简单查询

一.常用数据库软件

  • 大型数据库
  • Oracle Oracle是著名的Oracle(甲骨文)公司的数据库产品 , 它是世界上第一个商品化的关系型数据库管理系统 , 也是第一个推出和数据库结合的第四代语言开发工具的数据库产品。Oracle 公司的软件产品丰富 , 包括 Oracle 服务器产品 , Oracle 开发工具和Oracle 应用软件。其中最著名的就是 Oracle 数据库 , 目前最新的版本是 Oracle11g。
  • DB2 DB2 是 IBM 的关系型数据库管理系统 , DB2 有很多丌同的版本 , 可
    以运行在从掌上产品到大型机丌同的终端机器上。DB2 在高端数据库的主要竞争对手是 Oracle。
  • Sybase Sybase是美国Sybase公司研制的一种关系型数据库系统 , 是较早采用C/S 技术的数据库厂商 , 是一种典型的 UNIX 或 Windows NT 平台上客户机/服务器环境下 的大型数据库系统 , 在国内大中型系统中具有广泛的应用。
  • 中小型数据库
  • Sql Server Microsoft SQL Server 是运行在 Windows NT 服务器上 , 支持 C/S结构的数据库 管理系统。它采用标准 SQL 语言。? Mysql MySQL是一个小型关系型数据库管理系统 , 开发者为瑞典 MySQL AB公司。在 2008年 1 月 16 号被 Sun 公司收购。而 2009 年 SUN 又被 Oracle 收购。
  • Mysql MySQL 体积小、速度快、总体拥有成本低 , 尤其是开放源码 , 许多中小型网站为了降低网站总体拥有成本而选择了 MySQL 作为网站数据库。
  • 小型数据库
    Access Microsoft Office Access( 前名 Microsoft Access )是由微软发布的关联式数据库管理系统 , 是 Microsoft Office 的成员之一。

二.RDBMS( Relational Database Management System )

关系型数据库管理系统是数据库软件中用来操纵和管理数据库的部分 , 用亍建立、使用和维护数据库 , 简称 rdbms。它对数据进行统一的管理和控制 , 以保证数据的安全性和完整性。

三.SQL(Structured Query Language)

SQL( Structured Query Language )语言是用来在关系数据库上执行数据操作、检索及维护所使用的标准语言 , 是一个综合的、通用的关系数据库语言。大多数数据库都使用相同或者相似的语言来操作和维护数据库。SQL 语言可以用来查询数据 , 操纵数据 , 定义数据 , 控制数据 , 使软件开发人员、数据库管理员都可以通过 SQL 语言对数据库执行特定的操作。

四.DBA( Database Administrator )

数据库管理员

五.Table( 表 )

表是数据库存储的基本单元 , 对应亍现实世界中的实体对象 , 比如部门、职员等 , 表是一个二维结构 , 由行和列组成 , 横向为行(Row) , 也叫记(Record) , 用来表示实体的数据 , 比如一个职员的相关信息。纵向为列(Column) , 也叫作字段(Filed) , 用来表示实体的属性 , 比如职员的薪水。在软件开发技术比如 Java 中 , 现实世界的实体使用对象来描述 , 所以数据表和对象之间存在一种对应关系。数据表相当亍类(Class) , 数据表的行就是某个对象的实例(Instance) ,其中每个列都是对象实例的属性(Field)。

六.Oracle支持的数据类型

  • 数字
  • number(n) 数字( 最长 n 位 )
  • number(n , m) 浮点数( 总长 n 为 , 小数点后 m 位 )
  • 例:number(7,2) 表示最大数为 99999.99
  • 字符串
  • char(n) 表示定长字符串( 方便查询 )最长放入 n 个字符 , 放入的数据如果不够 n 个字符则补空格 , 无论如何都占 n 个字符长度。
  • varchar(n) 表示变长字符串( 节省空间 )最长放入 n 个字符 , 放入的数据是几个长度就占多大空间
  • varchar2(n) Oracle 自己定义的变长字符串
  • 日期
  • date 日期
  • 二进制
  • BLOB 二进制数据 最大长度4G

七.练习Sql语句

  • 1.建表
--建表
-- 表名不能超过 30 个字符
-- 表名、列名是自由定义的
-- 所有的 SQL 语句都是以“ ; ”结尾
CREATE TABLE user_test(
            id  number(4),
            password char(6),
            name char(20),
            phone char(11),
            email varchar(20)
);
  • 2.修改表格的列
alter table user_test modify email varchar(50);
  • 3插入数据
insert into user_test values(1001,'123456','张三','13468857714','linglongxin24@163.com');

*4. 查询数据

SELECT * from user_test;
  • 5.数据准备
  • 创建部门表并插入数据
CREATE TABLE dept_test(
            dept_id NUMBER(2),
            dept_name CHAR(20),
            dept_location CHAR(20)
);

desc dept_test;

INSERT INTO dept_test VALUES(10,'developer','beijing');

INSERT INTO dept_test VALUES(20,'account','shanghai');

INSERT INTO dept_test VALUES(30,'sales','guangzhou');

INSERT INTO dept_test VALUES(40,'operations','tianjin');

SELECT * FROM dept_test;
  • 创建员工表并插入数据
CREATE TABLE emp_test(

            emp_id NUMBER(4),
            name VARCHAR(20),
            job VARCHAR(20),
            salary NUMBER(7,2),
            bonus NUMBER(7,2),
            hire_date DATE,
            manager NUMBER(4),
            dept_test_id NUMBER(2)
);

DESC emp_test;

SELECT * FROM EMP_TEST;

INSERT INTO emp_test VALUES(1001,'张无忌','Manager','10000','2000',TO_DATE('2010-01-12','yyyy-mm-dd'),1005,10);
INSERT INTO emp_test VALUES(1002,'刘苍松','Analyst', 8000 , 1000 ,TO_DATE('2011-01-12','yyyy-mm-dd'),1001,10);
INSERT INTO emp_test VALUES(1003,'李翊' ,'Analyst',9000 , 1000 ,TO_DATE('2010-02-11','yyyy-mm-dd'),1001,10);
INSERT INTO emp_test VALUES(1004,'郭芙蓉','Programmer',5000, NULL ,TO_DATE('2010-02-11','yyyy-mm-dd'),1001,10);

INSERT INTO emp_test VALUES(1005 , '张三丰' , 'President' ,15000 , NULL ,TO_DATE('2008-02-15','yyyy-mm-dd'),NULL,20);
INSERT INTO emp_test VALUES(1006 , '燕小六' , 'Manager' ,5000 ,400 , '01-FEB-09' , 1005 , 20);
insert into emp_test values(1007 , '陆无双' , 'clerk' ,3000 , 500 , '01-FEB-09' , 1006 , 20) ;
insert into emp_test values(1008 , '黄蓉' , 'Manager' ,5000 , 500 , '1-MAY-09' , 1005 , 30) ;
insert into emp_test values(1009 , '韦小宝' , 'salesman' ,4000 , null , '20-FEB-09' , 1008 , 30) ;
insert into emp_test values(1010 , '郭靖' , 'salesman' ,4500 , 500 , '10-MAY-09' , 1008 , 30) ;



SELECT * FROM emp_test;
  • 6.练习基本查询语句
--计算员工的名字、月薪和年薪?
SELECT name,salary,salary*12 year_salary
    FROM emp_test;

--计算员工的月收入?
--空值和任何数据做算数运算 , 结果为空(null)
--正确写法:如果 bunus 的值是 null , 则取 0
SELECT name,salary,bonus,salary+ nvl(bonus,0) month_salary
    FROM emp_test;

--指定字段揑入值
    INSERT INTO emp_test (emp_id,name) VALUES(1011,'于泽成');

--查询 emp_xxx 表 , 如果没有职位 , 显示'no position' , 如果有职位 , 显示员工的职位
SELECT name,NVL(job,'no positon') job
            FROM emp_test;

--查询 emp_xxx 表 , 如果没有入职时间 , 显示为 2016-12-12 , 否则原样显示
SELECT name,NVL(hire_date,TO_DATE('2016-12-12','yyyy-mm-dd')) hire_date
            FROM emp_test;

--连接字符串用CONCAT(str1,str2,...)和Oracle有区别,Oracle用||
SELECT emp_id,name||' job is '||job detail
            FROM emp_test;
--复制表
CREATE TABLE emp_test2 AS SELECT * FROM emp_test;
SELECT * FROM emp_test2;

--DISTINCT注意:distinct 必须( 只能 )跟在 select 后边,distinct 指所有列的唯一组合
--机构中有多少种职位?
SELECT DISTINCT job FROM emp_test;
--员工分布在哪些部门?
SELECT DISTINCT dept_test_id FROM emp_test;
--查询每个部门不重复的职位
SELECT DISTINCT job,dept_test_id FROM emp_test;

--薪水高亍 10000 元的员工数据?
SELECT * FROM emp_test WHERE salary>10000; 

--职位是 Analyst 的员工数据?SQL 语句大小写丌敏感 , 数据大小写敏感
SELECT * FROM emp_test WHERE LOWER(job)='analyst'; 

--薪水大亍 5000 并且小亍 10000 的员工数据?>=<=;between and
SELECT * FROM emp_test WHERE salary>=5000 AND salary<=10000; 
SELECT * FROM emp_test WHERE salary BETWEEN 5000 AND 10000; 

--入职时间在 2011 年的员工?
--错误写法
SELECT * FROM emp_test WHERE hire_date=TO_DATE('2011','yyyy'); 
--正确写法
SELECT * FROM emp_test WHERE hire_date BETWEEN TO_DATE('2011-01-01','yyyy-mm-dd') AND TO_DATE('2011-12-31','yyyy-mm-dd') ; 


--列出职位是 Manager 或者 Analyst 的员工
SELECT * FROM emp_test WHERE job IN('Manager','Analyst');

--列出职位中包含有 sales 字符的员工数据?
SELECT * FROM emp_test WHERE LOWER(job) LIKE '%sales%';

--列出职位中第二个字符是 a 的员工数据?
SELECT * FROM emp_test WHERE LOWER(job) LIKE '_a%' ;

--查询数据库中有多少个名字中包含 'EMP' 的表?
SELECT COUNT(*) FROM USER_TABLES WHERE TABLE_NAME LIKE '%EMP%';


SELECT * FROM emp_test;

-- 查询哪些员工没有奖金?
SELECT * FROM emp_test WHERE bonus IS NULL;

--薪水丌在 5000 至 8000 的员工?
SELECT * FROM emp_test WHERE salary NOT BETWEEN 5000 AND 8000;

--不是部门 20 和部门 30 的员工?
SELECT * FROM emp_test WHERE dept_test_id NOT IN(20,30);

insert into emp_test values(1012 , 'text_test' , 'salesman' ,4500 , 500 , TO_DATE('2011-01-01','yyyy-mm-dd') , 1008 , 30) ;
--如果要查询的数据中有特殊字符( 比如_或% ),
-- 在做模糊查询时 ,
-- 需要加上\符号表示转义 , 如果是Oracle并且用 escape 短语指明转义字符\mysql不用
SELECT name FROM emp_test WHERE name LIKE '%\_%' ESCAPE '\' ;


最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容