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

SQL SERVER ——表的基本操作

一,常用关键词

primary key

主键

references 表名(列名)

引用外键

check(列名=‘约束样例’)

约束条件

default(‘默认值’)

默认值

not null

非空

unique

唯一

default(getdate())

获取当前时间

identity(1,2)

自动增长,初始值1,增长步长2

creatr

创建

add

添加

drop

删除

table

column

CONSTRAINT

约束

二,创建表

创建表的前提是存在一个数据库,存储要创建的表,若还没有数据库,则需要先创建数据库

create database (数据库名)--创建数据库

有了一个数据库后在该数据库创建表

--切换数据库
use Schooldb

--创建表
create table Student 
(
	--创建列
	Stu_id	int		primary key	NOT NULL,
	Stu_name varchar(20) NOT NULL,
	Stu_sex varchar(2) NOT NULL check(Stu_sex='男' or Stu_sex='女') default('男'),
	age 	int		,	
	Brithdate	date NOT NULL,
	Phone1 varchar(11)	unique,
	Phone2 varchar(11)	unique,
	Address varchar(100),
	Class_id varchar(4)								
)

CREATE TABLE Course
(
    -- 创建列
    Course_id VARCHAR(5) PRIMARY KEY  NOT NULL,
	Course_name VARCHAR(20) NOT NULL,
    Course_hour smallint NOT NULL,
    Introduce VARCHAR(200)
);

CREATE TABLE StudentGrade
(
    -- 创建列
    Stu_id INT NOT NULL	references Student(Stu_id),
    Course_id VARCHAR(5) NOT NULL references Course(Course_id),
    Grade smallint 
    -- 设置组合主键
    PRIMARY KEY (Stu_id, Course_id)
);

三,删除表

--判断表是否存在
if exists(select *from sys.objects where name='表名'and type ='U')
drop table	表名--若存在则删除表

四,修改表结构

1.添加列

--alter table 表名 add 新列名 数据类型
alter table People add name vachar(20)

--示例
use Schooldb
	alter table StudentGrade add point float

2.删除列

--alter table 表名 drop 列名
alter table People drop column name

--示例
alter table studentGrade drop column point 

四,列的常用操作

1.添加约束

添加约束
--alter table 表名 add constarint	约束名 check(表达式)
alter table Course add CONSTRAINT year check (year BETWEEN 2006 AND 2020);

--添加约束(主键)
--alter table 表名 add constarint	约束名 primary key(列名) 
alter table Course add CONSTRAINT  primary key (year);

--添加约束(唯一)
--alter table 表名 add constarint 约束名	unique(列名) 
alter table Course add CONSTRAINT UQ_Year_Unique unique(year)

--添加约束(默认)
--alter table 表名 add constarint	约束名 default 默认值 for 列名
	alter table Course add CONSTRAINT DF_Year_Default default 2000 for year;

--添加约束(外键)
--alter table 表名 add constarint 约束名	foreign key(列名) reference 关联的表名(列名)
alter table Course add CONSTRAINT FK_Year_OtherTable
FOREIGN KEY (year) REFERENCES OtherTable(OtherColumn);

2.删除约束

--alter table 表名 drop constarint 约束名

五,具体操作

--新建数据库
create database Schooldb
on
(	
	name='School.amd',--逻辑文件名
	filename='D:dataDBSchool.amd',--物理地址
	size=10MB,--文件初始大小
	filegrowth=10%--文件增长方式
)
log on
(
	name='School.lmd',--逻辑文件名
	filename='D:dataDBSchool.lmd',--物理地址
	size=10MB,--文件初始大小
	filegrowth=10%--文件增长方式
)
--切换数据库
use Schooldb

--创建表
create table Student 
(
	--创建列
	Stu_id	int		primary key	NOT NULL,
	Stu_name varchar(20) NOT NULL,
	Stu_sex varchar(2) NOT NULL check(Stu_sex='男' or Stu_sex='女') default('男'),
	age 	int		,	
	Brithdate	date NOT NULL,
	Phone1 varchar(11)	unique,
	Phone2 varchar(11)	unique,
	Address varchar(100),
	Class_id varchar(4)								
)

CREATE TABLE Course
(
    -- 创建列
    Course_id VARCHAR(5) PRIMARY KEY  NOT NULL,
	Course_name VARCHAR(20) NOT NULL,
    Course_hour smallint NOT NULL,
    Introduce VARCHAR(200)
);

CREATE TABLE StudentGrade
(
    -- 创建列
    Stu_id INT NOT NULL	references Student(Stu_id),
    Course_id VARCHAR(5) NOT NULL references Course(Course_id),
    Grade smallint 
    -- 设置组合主键
    PRIMARY KEY (Stu_id, Course_id)
);
	
	use Schooldb
	--添加列
	alter table Course add year int
	--修改数据类型
	alter table Course alter  column year smallint
	--添加约束
	alter table Course add CONSTRAINT year CHECK (year BETWEEN 2006 AND 2020);--普通条件约束
	alter table Course add CONSTRAINT UQ_Year_Unique unique(year);--唯一约束
	alter table Course add CONSTRAINT  PK_Year PRIMARY KEY (year);--主键
	alter table Course add CONSTRAINT DF_Year_Default DEFAULT 2000 FOR year;--默认
	alter table Course add CONSTRAINT FK_Year_OtherTable
FOREIGN KEY (year) REFERENCES OtherTable(OtherColumn);--外键

	--删除列
	alter table Course drop column year

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

相关文章:

  • 【工具整理】WIN换MAC机器使用工具整理
  • Ⅱ.INTRODUCTION TO CUDA C
  • 大数据系列之:深入理解学习使用腾讯COS和COS Ranger权限体系解决方案,从hdfs同步数据到cos
  • React 中结合 antd 的 Input 组件实现防抖输入
  • BGP基础配置实验
  • C++ —— 智能指针
  • 系统思考—信任
  • 解决安装pynini和WeTextProcessing报错问题
  • git 添加代理
  • 云手机:虚拟技术的革命性应用与实体手机的优劣对比
  • 小米PK霍尼韦尔宠物空气净化器谁更强?还有其他专业品牌吗?
  • 《燕云十六声》游戏文件tcj.dll已损坏怎么办?
  • XCode如何知道所打开源码文件的路径
  • 关于Spring的专项面试试题总结
  • DAY196-vpc1-小迪安全
  • HarmonyOS NEXT 应用开发练习:智能视频推荐
  • pdf预览兼容问题- chrome浏览器105及一下预览不了
  • 鸿蒙设置字体或者背景颜色渐变
  • 【SOC 芯片设计 DFT 学习专栏 -- DFT std logic 介绍 】
  • IP-MS常见问题(一)
  • std::shared_mutex学习
  • 二叉树遍历:C++ 实现指南
  • Python的*args和**kwargs
  • Word如何插入图片并移动到某个位置
  • 173. 矩阵距离 acwing -多路BFS
  • 【 IEEE 独立出版 · EI核心、Scopus稳定检索 】第二届算法、软件工程与网络安全国际学术会议(ASENS 2025)