没有合适的资源?快使用搜索试试~ 我知道了~
Oracle创建主键自增表,Oracle的基本操作+Oracle字段类型,命名规则和注意事项
资源推荐
资源详情
资源评论
powerdesigner 版本 12.5 创建表就不说了。
下面开始介绍设置自动增长列。
1 在表视图的列上创建。
双击表视图,打开 table properties ———>columens , 双击要设置的列(显示列的序号
的那个按钮,单击后,会显示横向的黑色箭头)。 打开 column properties 对话框。在
‘ general’ 项 中 , 最 下 面 , 找 到 sequence , 下 拉 框 后 面 , 有 三 个 按 钮 就
‘create’,‘ select’,‘ properties’。 新建的话就点击‘create' 打开 sequence properties 对话框,
general 中的 name, code 随意修改 切换到 physical options 项,输入下面几项内容 start with
1 increment by 1 minvalue 1 maxvalue 根据自己需要决定是否要设定。没有的话,选择 no
max value no cache 勾选 输入完后,点击应用。创建完毕。在 preview 中 可以看到相应的
创建代码 同时,在 table properties———>preview 的创建代码中,自动加入了 触发器
trigger 的创建代码。 创建完成使用:到 table properties———>preview 中拷贝 table 的创建
代码,赋值到 plsql 中执行。 提示:不知道是我的 powerdesigner 设置问题还是怎么回事,
table 的创建代码中没有自动加入 sequence 的创建部分。 所以,还要到 sequence properties
———>preview 中,把 sequence 的创建代码拷贝到 表创建的代码中 放到 cteate table .... 和
create trigger ...中间
例如: create table G_EC_LotteryCategory (
lcId NUMBER(3) not null,
lcName NVARCHAR2(30),
lcAbbr NVARCHAR2(20),
constraint PK_G_EC_LOTTERYCATEGORY primary key (lcId)
)
/
create sequence Sequence_LotCateID
increment by 1
start with 1
nomaxvalue
minvalue 1
nocache;
create trigger tib_g_ec_lotterycategory before insert
on G_EC_LotteryCategory for each row
declare
integrity_error exception;
errno integer;
errmsg char(200);
dummy integer;
found boolean;
begin
--Column lcId uses sequence Sequence_LotCateID
select Sequence_LotCateID.NEXTVAL INTO :new.lcId from dual;
--Errors handling
exception
when integrity_error then
raise_application_error(errno, errmsg);
end;
/
在 plsql 中执行上端代码。创建表;
添加记录测试;
insert into G_EC_LotteryCategory(lcName,lcAbbr) values('1','1');
insert into G_EC_LotteryCategory(lcName,lcAbbr) values('2','2');
查询后,看到的的 id 列是自动增长的。
2 先创建,然后在列的 sequence 项中选择。
在 powerdesigner 左边的树中,你的 model 项目的子菜单中有 sequence ,右键点击——>
new
打开 sequence properties 对话框,添加内容上面的方法类似。
完场后,还是到表视图中,双击列名,打开 column properties 对话框。
general——> sequence 的下拉框中就出现了刚才创建的 sequence ,选中,保存即可
Oracle 创建主键自增表
1、创建表««««
create?table?Test?(userid?number(10)?NOT?NULL?primary?key,??/*主键,自动增加*/????????????
username?varchar2(20));?
2、创建自动增长序列«««
?Create?Sequence?Test_Sequence??Increment?by?1?????--?每次加几个««««««««
start?with?1?????--?从 1 开始计数«««
?nomaxvalue????--?不设置最大值««,设置最大值:maxvalue?9999??????
nocycle????????--?一直累加,不循环««««««««
cache?10;????
3、创建触发器«««
Create?trigger?Test?before?insert?on?test?for?each?row?????????/*对每一行都检测是否触发*/?
begin?
select?Test_Sequence.nextval?into:New.userid?from?dual;?
end;?/*退出 sqlplus 行编辑*/???
4、提交«««
commit;??
5、测试«««
insert?into?Test?(Username)?values('test');?
CREATE TABLE cd_study_detail
(
row_id VARCHAR2(20) UNIQUE,
id_card VARCHAR2(20) PRIMARY KEY,
study_date DATE CHECK (study_date LIKE '%-%-%'),
study_desc VARCHAR2(50) ,
study_sco NUMBER(10,1),
CONSTRAINT dtudy_role_fk FOREIGN KEY(id_card) REFERENCES neu_study(id_card)
);
建表示例:
CREATE TABLE neu_study (
剩余7页未读,继续阅读
资源评论
wjfs2005
- 粉丝: 0
- 资源: 3
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功