SQL Server创建及修改表实验报告(下)

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介: SQL Server创建及修改表实验报告(上)

3-15修改student表中的sname列为非空约束

altertablestudent

altercolumnsnamechar(16)notnull

3-16XSCJ数据库中创建student结构为(snochar(10),snamechar(6),ssexchar(2),sageint,sdeptchar(15)),其中sno为主键

CREATETABLEstudent

(

snochar(10)PRIMARYKEY,

snamechar(6),

ssexchar(2),

sageint,

sdeptchar(15)

)

3-17XSCJ数据库创建一个sc其结构是sc(snochar(10),cnochar(4),gradeint),其中主键为sno+cno

USEXSCJ

GO

createtablesc

(

snochar(10),

cnochar(4),

gradeint,

PRIMARYKEY(sno,cno)

)

3-18 XSCJ数据库中的数据表(course)添加课程号为主键约束约束名为PK

altertablecourse

ADDCONSTRAINTPKPRIMARYKEY(cno)

3-19 XSCJ数据库中的student表和sc表之间建立外键约束其中sc表中的sno为外键参照student表中的sno

createtablesc

(

snochar(10)CONSTRAINTFK_snoFOREIGNKEYREFERENCESstudent(sno),

cnochar(4),

gradeint,

PRIMARYKEY(sno,cno)

)

3-20XSCJ数据库中的选课表sc中的课程号cno建立外键约束该列值参照课程表的课程号cno

altertablesc

ADDCONSTRAINTS  FKFOREIGNKEY(cno)REFERENCEScourse(cno)

3-21创建student表时sname列创建唯一约束

createtablestudent

(

snochar(10)CONSTRAINTpk_snoPRIMARYKEY,

snamechar(6)CONSTRAINTUN_snameUNIQUE,

ssexchar(2),

sageint,

sdeptchar(15)

)

3-22创建sc表时限制grade列的值只能在-100之间

createtablesc

(

snochar(10)CONSTRAINTFK_snoFOREIGNKEYREFERENCESstudent(sno),

cnochar(4)CONSTRAINTFK_cnoFOREIGNKEYREFERENCEScourse(cno),

gradeintCHECK(grade>=0 andgrade<=100),

PRIMARYKEY(sno,cno)

)

3-23创建student表时ssex列只能取男或女且默认值是男

createtablestudent

(

snochar(10)CONSTRAINTpk_snoPRIMARYKEY,

snamechar(6),

ssexchar(2)CHECK (ssex=''orssex='')DEFAULT'',

sageint,

sdeptchar(15)

)

5.实验数据记录与整理:

(1)添加主键约束,在sc表中设置主键时遇到以下情况:

因为学号原本是允许空的,要修改学号这个字段是非空的才可以,课程号也是一样

进行正确的非空操作如下图:

这里容易出错的地方见下图:

注意修改非空的代码是alter table sc,而不是alter table student或者alter table course

(2)两把钥匙不是两个主键,而是两个合成一个主键

(3)在删除student表时遇到以下情况:

因为该对象有一个外键约束,student是一个主表,而sc表是一个从表和它相关联的,互相引用的所以不能删除。想删除必须先删除从表,然后再删除主表。所以应该先drop table sc 然后drop table student

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
8天前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
3月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
68 13
|
3月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
|
3月前
|
SQL 存储 网络安全
关系数据库SQLserver 安装 SQL Server
【7月更文挑战第26天】
48 6
|
3月前
|
SQL 监控 关系型数据库
PolarDB产品使用问题之SQL防火墙怎么拦截没有指定WHERE条件的特定表的SQL语
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
2月前
|
SQL 存储 安全
SQL视图实验:创建、查询与管理技巧
在数据库管理系统中,视图(View)是一个虚拟表,其内容由查询定义
|
2月前
|
SQL 安全 Java
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
232 0
|
3月前
|
存储 SQL C++
对比 SQL Server中的VARCHAR(max) 与VARCHAR(n) 数据类型
【7月更文挑战7天】SQL Server 中的 VARCHAR(max) vs VARCHAR(n): - VARCHAR(n) 存储最多 n 个字符(1-8000),适合短文本。 - VARCHAR(max) 可存储约 21 亿个字符,适合大量文本。 - VARCHAR(n) 在处理小数据时性能更好,空间固定。 - VARCHAR(max) 对于大文本更合适,但可能影响性能。 - 选择取决于数据长度预期和业务需求。
151 1
|
3月前
|
SQL 存储 数据库
MySQL设计规约问题之如何处理日志类型的表
MySQL设计规约问题之如何处理日志类型的表
|
3月前
|
SQL 监控 数据库
SQL Server 查询超时问题排查
【7月更文挑战第8天】排查 SQL Server 查询超时涉及五个主要方面:检查复杂查询、评估服务器性能、审视配置参数、更新统计信息和分析执行计划。关注点包括查询的结构(如连接、子查询和索引),服务器资源(CPU、内存、网络延迟),连接和内存设置,以及统计信息的时效性。通过这些步骤可定位并解决性能瓶颈。
下一篇
无影云桌面