当前位置: 首页 > article >正文

【SQL Server】教材数据库(1)

1 利用sql建立教材数据库,并定义以下基本表:

学生(学号,年龄,性别,系名)

教材(编号,书名,出版社编号,价格)

订购(学号,书号,数量)

出版社(编号,名称,地址)

定义主码、外码、和价格、数量的取值范围。

2 在三个表中输入若干记录,注意如果输入违反完整性约束条件的记录系统有何反应。

新建查询,使用sql语句创建教材数据库

create database jiaocai                   
on primary(
  name = jiaocai,
  filename = 'D:\data_place\jiaocai_data.mdf',
  size = 10mb,
  filegrowth = 1mb
)

log on(
  name = jiaocai_log,
  filename =  'D:\data_place\jiaocai_data.ldf', 
  size = 5mb,
  maxsize = 15mb,
  filegrowth = 10%
)

分别创建学生,教材,出版社,订购表,为属性添加约束。

use jiaocai
create table student(
  id        varchar(30) primary key not null,
  name      varchar(10) not null,
  age       int,
  sex       varchar(6),
  dept      varchar(10)
)   
create table publish(
  id        varchar(30) primary key not null,
  name      varchar(20) not null,
  address   varchar(40)
)
create table book(
  id        varchar(30) primary key not null,
  title     varchar(30),
  c_id      varchar(30) foreign key references publish(id),
  price     int check(price > 0 and price < 200)
)
create table orders(
  s_id      varchar(30) foreign key references student(id),
  b_id      varchar(30) foreign key references book(id),
  number    int check(number > 0 and number < 2000)
)

使用insert into批量向各个表中添加数据


insert into dbo.student(id,name,age,sex,dept) 
values
('2201331','张伟',18,'男','计算机'),
('2202332','王晶',20,'男','光电'),
('2203333','刘丽',19,'女','汉语言'),
('2204334','严正',21,'男','大数据'),
('2205335','蒋婷',18,'女','汉语言'),
('2206336','杨智',19,'女','英语'),
('2207337','周子涵',20,'男','俄语'),
('2208338','王飞',19,'男','机电'),
('2209339','吴昊',18,'女','中文'),
('2210340','徐峰',20,'男','计算机')
insert into dbo.publish(id,name,address)values
('jj01','安徽出版社','安徽'),
('gg01','高教出版社','北京'),
('dd01','长春出版社','长春'),
('aa01','九州出版社','海口'),
('ee01','江苏出版社','江苏'),
('hh01','重庆出版社','重庆'),
('zz01','青岛出版社','青岛'),
('yy01','山东出版社','山东')
insert into dbo.book(id,title,c_id,price)values
('j1','C语言','jj01',50),
('g1','光学应用基础','gg01',68),
('h1','中国古代诗选','hh01',58),
('d1','spark语言基础','dd01',77),
('y1','商务英语','yy01',30),
('e1','计算机俄语','ee01',88),
('a1','机械制图','aa01',56),
('z1','大学语文','zz01',40)
insert into dbo.orders(s_id,b_id,number)values
('2201331','j1',1),
('2202332','g1',2),
('2203333','h1',1),
('2204334','d1',1),
('2205335','y1',1),
('2206336','e1',1),
('2207337','a1',1),
('2208338','z1',1)

这样数据库和对应的带有数据的数据表就创建好了。

use jiaocai
insert into dbo.student(id,name,age,sex,dept) 
values('2209339','王明义',19,'男','计算机')

执行以上sql语句发现添加数据失败,原因是学号作为主键,主键具有唯一标识不能重复。

更换学号后执行成功


http://www.kler.cn/a/463728.html

相关文章:

  • 深入理解 JVM 的垃圾收集器:CMS、G1、ZGC
  • xilinx的高速接口构成原理和连接结构及ibert工具的使用-以k7 GTX为例
  • 多层设计模式:可否设计各层之间公用的数据定义模块?
  • NLP 中文拼写检测纠正论文-07-NLPTEA-2020中文语法错误诊断共享任务概述
  • 供需平台信息发布付费查看小程序系统开发方案
  • 禁用div的写法(自定义disabled)Vue3
  • Javascript数据结构常见题目(一)
  • Harmony OS 开发-ArkUI框架速成一
  • 【深度学习】多目标融合算法—样本Loss提权
  • 2024 年发布的 Android AI 手机都有什么功能?
  • springboot529基于JavaWeb的本科生交流培养管理平台的设计与实现(论文+源码)_kaic
  • C++:Windows 多线程 简单示例
  • Ubuntu 24.04安装和使用WPS 2019
  • 2412d,d语言中写汇编
  • 机器学习 LightGBM 算法原理解析
  • QT---------GUI程序设计基础
  • Linux下Shell编程之sed命令详解及示例
  • C#语言的字符串处理
  • 上位机开发 的算法与数据结构
  • ƒ () { [native code] } 的解释
  • Linux驱动开发 IIC I2C驱动 编写APP访问EEPROM AT24C02
  • c#枚举和结构体类型详解
  • 【2024年-6月-28日-开源社区openEuler实践记录】探索 easy - software:简化软件部署与管理的开源方案
  • Ubuntu如何安装jdk并切换到不同的jdk版本
  • 【gopher的java学习笔记】mybatis的mapper是什么
  • 【C++】模板使用总结