SQLServer数据库应用与开发:第四章上机

这段内容涉及了数据库表的创建、插入、更新和删除操作,以及规则创建和绑定。创建了book表和author表,定义了主键和外键约束,并设置了数据检查规则。此外,还展示了如何对booksales表进行数据插入、更新和删除操作。
摘要由CSDN通过智能技术生成

代码及解释

4.1

create table book(
book_id nchar(6) not null,
book_name nchar(30) null,
price numeric(10,2) null
constraint PK_book_id primary key clustered(
book_id asc
)
)on [primary]

create table author(
author_name nchar(4),
book_id nchar(6),
address nchar(30),
)on [primary]

alter table author
with check
add constraint FK_book foreign key(book_id)
references book(book_id)

解释:
1.constraint为约束,PK_book为主键索引名,clustered为聚集索引(就是将数据排序后再加上索引)
2.asc为按值升序
3.on[primary]在主文件组,可以不加
4.references后面是主键表的主键
5.外键就是一个关系的属性在另一个关系中为主键,则称这个属性为外键
6.with check
7.创建表的结构:名字+类型+是否为空

4.2

use test01
create table booksales
(
book_id nchar(6) null,
sellnum int null,
selldate date null
)

insert into booksales(book_id,sellnum,selldate)
values('1',2,'2019-03-30')
insert into booksales
values('2',3,'2019-12-12')

update booksales
set selldate='2013-01-1'
where book_id='2'

delete from booksales
where book_id='1'

解释:
1.date要记得加上引号,格式为’yyyy-mm-dd’

4.3

use test01
go
create rule sell_rule
as
@sells>=0
go

sp_bindrule 'sell_rule','booksales.sellnum'

解释:
1.创建规则的语句一定要用go语句,否则会报错:create rule要使用批处理语句
2.代码中@sells可以改为任意字符但是要加@符号

4.4

delete from booksales
where year(selldate)<2015

truncate table booksales

drop table booksales

解释:
1.数据库日期类型数据可以直接比较例如selldate<‘1/1/2015’

参考资料

创建主键
数据库索引
索引命名规范
聚集索引和非聚集索引(整理)
数据库的索引与主键

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值