11、Oracle自增和简单查询

学习目标:

1、了解主键自增的设置

2、掌握select的基础语法

学习过程:

今天我们开始学习数据库语言的DML部分。

一、建立今天课程所需要的数据库。

1、建表。

我们先设计今天要操作的表的结构,使用powerDesigner设计的E-R图如下:

attcontent/f81f6d00-f477-4a74-b753-b6a81858bc85.png

生成sql语言如下:

create table departrment 
(

   dep_id             INT                  not null,
   dep_name           VARCHAR(200),
   constraint PK_DEPARTRMENT primary key (dep_id)
);



create table employee 
(
   employee_id        int                  not null,
   dep_id             INT,
   employee_num       CHAR(10),
   employee_name      VARCHAR(50),
   salary             NUMBER(9,2),
   grps               INT,
   update_sir         INT,
   constraint PK_EMPLOYEE primary key (employee_id)
);



alter table employee
   add constraint FK_EMPLOYEE_REFERENCE_DEPARTRM foreign key (dep_id)
      references departrment (dep_id);

使用pl/developer运行上面的代码建表。

2、oracle的主键自增。

昨天我们讲过每一个表我们都会设置一个物理主键,这个物理主机和业务逻辑是没有任何关系,只是作为每一行数据的唯一标识,所以它一般不是由用户维护的,交给数据库自动维护,数据库一般会让主键自增,达到每次生成的主键都会唯一。不同数据库对主键的自增的实现方式不一样,其中Oracle数据的实现方式最为灵活,当然也比较麻烦。具体步骤如下:

(1)为每一张表都新建序列

attcontent/26b63b08-ef65-45a1-a5ad-824fb3ead203.png

输入序列的名称即可,其他就采用默认值即可。

attcontent/a96446b2-df25-4ce1-8e4f-6e1469de6b99.png

(2)为表添加一个触发器。

attcontent/17da4c0d-c013-4517-af4d-38214fc09fc3.png

(3)输入触发器名称,选择序列和需要自增的主键即可。

attcontent/936fa4d1-b349-42a1-85c3-8718448d1f28.png

同样的步骤为department表设置一个自增的触发器。

二、基本查询。

一般建议书写sql语言注意一下几个问题:

  • SQL语句不区分大小写
  • SQL语句可以分成一行或者多行写。
  • 关键字不可以简写或者分行书写
  • 子句通常分行写
  • 使用缩进提高可读性
  • 关键字通常用大写,其他的词像表名或者列名用小写。

当然有些只是建议,比如关键字你也可以是小写的。

最简单的查询语句的格式如下:

SELECT *|column FROM table_name .

SELECT指定显示的列,FROM指定所选择的列来自哪张表。

检索所有的行和列代码如下:

select * from employee

你也可以不查询全部的列,使用投影查询,只查询自己需要的列。代码如下

select employee_name,salary from employee

定义一个列的别名,对列的标题重命名 n方便计算 n在列的名称后可以紧跟别名—或者使用可选的关键字AS放在列名和别名之间 n如果别名包含空格或特殊字符或对大小写敏感,需要双引号引用。代码如下

select employee_name as  姓名,salary as  工资 from employee

还可以使用数学运算符

	
select employee_name as  姓名,salary+salary*05 as 工资 from employee

也可以使用字符串的连接,字符串连接和java不同,使用||

--字符串的链接  '' 链接||
select employee_name||'先生' as  姓名,salary+salary*05 as 工资 from employee

可以使用distinct 去了删除冗余行

select distinct employee_name from employee

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值