学习目标:
1、了解主键自增的设置
2、掌握select的基础语法
学习过程:
今天我们开始学习数据库语言的DML部分。
一、建立今天课程所需要的数据库。
1、建表。
我们先设计今天要操作的表的结构,使用powerDesigner设计的E-R图如下:
生成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)为每一张表都新建序列
输入序列的名称即可,其他就采用默认值即可。
(2)为表添加一个触发器。
(3)输入触发器名称,选择序列和需要自增的主键即可。
同样的步骤为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