修改表的结构
DDL定义中对于数据库的操作主要有3种语法
- 创建对象:CREATE 对象类型 对象名称….
- 删除对象 DROP 对象类型 对象名称
- 修改对象 ALTER 对象类型 对象名称
创建表,并添加数据
--删除member表
DROP TABLE MEMBER PURGE;
--创建member表
CREATE TABLE member(
mid NUMBER(5),
name VARCHAR2(50) DEFAULT '无名氏'
);
--查看当前用户下的全部表
SELECT * FROM tab;
--查看member表的结构是否正确
DESC MEMBER;
--向表中添加若干条记录
INSERT INTO MEMBER(mid,NAME)
VALUES(1,'张三');
INSERT INTO MEMBER(mid,NAME)
VALUES(2,'李四');
INSERT INTO MEMBER(mid,NAME)
VALUES(3,'王五');
--查询member表
SELECT * FROM MEMBER;
示例一、
向member表中增加3个字段
ALTER TABLE MEMBER ADD(age NUMBER(3)); --增加年龄字段 ALTER TABLE MEMBER ADD(sex VARCHAR2(10) DEFAULT '男'); --增加性别字段 ALTER TABLE MEMBER ADD(phote VARCHAR2(100) DEFAULT 'nophote.jpg'); --增加图像 --查直表结构 DESC MEMBER;
--发现已经增加成功
修改表的字段
ALTER TABLE 表名称 MODIFY(字段名称 字段类型 DEFAULT 默认值);
示例二、
将name 字段长度修改为30,将sex字段的,默认值修改为女
ALTER TABLE MEMBER MODIFY(NAME VARCHAR2(30)); --将字段长度由50修改为30
ALTER TABLE MEMBER MODIFY(sex VARCHAR2(3) DEFAULT '女'); --将性别字段设置为长度3,并有默认值女
--查直表结构
DESC MEMBER;
--删除表中的字段
ALTER TABLE 表名称 DROP COLUMN 列名称;
示例三、
--删除member表中的phote和age字段
ALTER TABLE MEMBER DROP COLUMN phote;
ALTER TABLE MEMBER DROP COLUMN sex;
--查看表结构
DESC MEMBER;
将表中的一些字段设置为无用状态
ALTER TABLE 表名称 SET UNUSED(列名称)
ALTER TABLE 表名称 SET UNUSED column列名称
示例四、
将member中的age设置为无用状态
ALTER TABLE MEMBER SET UNUSED COLUMN age;
--查直表结构
DESC MEMBER;
--查询member表
SELECT * FROM MEMBER;
--设置为无用后,不会显示
删除表中的无用列
ALTER TABLE 表名称 DROP UNUSED COLUMNS;
--删除member列中的无用列
ALTER TABLE MEMBER DROP UNUSED COLUMNS;
添加注释
语法:
COMM ON TABLE 表名称 | COLUMN 表名称.列名称 IS ‘注释内容’;
查看user_tab_comments数据字典 SELECT * FROM User_Tab_Comments WHERE table_name='MEMBER'; --默认comments(注释)这个内容是NULL
为member表添加注释
COMMENT ON TABLE MEMBER IS '这是来学习的会员表'; ---查看member表注释 SELECT * FROM User_Tab_Comments WHERE table_name='MEMBER';
查看列的注释信息
SELECT * FROM user_col_comments WHERE table_name='MEMBER';
为mid,name,age birthday添加注释
COMMENT ON COLUMN member.mid IS '参加活动的会员编号'; COMMENT ON COLUMN member.name IS '参加活动的会员姓名'; COMMENT ON COLUMN member.age IS '参加活动的会员年龄'; COMMENT ON COLUMN member.Birthday IS '参加活动的会员生日'; --查看列的注释信息 SELECT * FROM user_col_comments WHERE table_name='MEMBER';