【数据库原理复习】ch2 SQL语句(主要基于sql server)
创始人
2024-05-29 13:07:55
0

这里写目录标题

  • 基本知识
    • 常用基本数据类型
      • 字符型数据类型
      • 二进制数据类型
      • 日期类型
      • 数字类型
    • 约束条件
  • 表SQL语句
    • 创建语句
    • 修改基本表 & 删除基本表
    • 数据查询

基本知识

常用基本数据类型

字符型数据类型

名称大小说明
char(n)占n个字节只能显示英文字符
nchar(n)2n字节+2字节额外开销Unicode编码,支持中文
ntext每字符2字节Unicode编码
nvarchar(max)2n字节 + 2字节额外开销根据存储字符数字节占用空间动态变化,Unicode
varchar(n)n字节 + 2字节额外开销仅支持英文,动态变化

二进制数据类型

名称大小
binary(n)占n个字节
image每个字符1字节
varbinary(n)每字符1字节
varbinary(max)每字符1字节 + 2字节额外开销

日期类型

名称大小说明
Date占3个字节保存月日
Datetime8个字节保存年月日秒,精确到最近的3,3ms

数字类型

  • 整型:int
  • 近似数据类型:float
  • numeric(p ,q):总共有p位数,小数后面有d位
  • 逻辑数据类型:bit, 仅取1,0或null

Null:表示当前字段值未知,未插入,不可用,或者稍后添加等。
Default:表示表中数据默认取值。

约束条件

  • 非空约束(not null):限制当前列数据都不为空。
  • 默认约束(default):为这个数据列定义一个默认值
  • 唯一性约束(unique):表示当前列的所有数据都不重复(除了null,可以有多个null)
  • 主键约束(primary key):表示这个或者这几个字段标识某一行数据
  • 外键约束(foreign key):根据另外一个表的某个列获得的数据进行有效值判定,通常是另外一个表的主键
  • 检查约束(check):对列进行约束,一般是自定义的表达式。

unique约束与not null 约束没有关系, unique只限制有值的情况下每一个值不能相同,可以有多个null 值。

表SQL语句

创建语句

create table table_name(# 是括号字段名1 类型  额外条件(没有就省略), # 逗号隔开字段名2 类型 额外条件,xxxx,xxx
)create table 表名
(<列名> <数据类型> [<列级完整性约束>],<列名> <数据类型> [<列级完整性约束>],xxxx,[<表级完整性约束条件>]
)
# 具体例子
create table student_table(stu_no char(10) Primary key,name char(6) Not Null,sex char(2),birthday Datetime,class_no char(4) 	# 最后一个不需要逗号
)
# 表级完整性约束定义
Primary key(字段名1, 字段名2, 。。。。) # 主码定义
FOREIGN KEY (字段1) REFERENCES 表名(字段名2)# 外键定义
  • 如果主码由属性组组成,需要作为表级完整性进行定义

修改基本表 & 删除基本表

Alter table <表名>[add <新列名> <数据类型> [完整性约束]]	# 添加新列[drop <完整性约束名>]					# 删除完整性约束[alter column <列名> <数据类型>];		# 修改原有的列定义Drop table <表名> [restrict | cascade]
  • 删除时,cascade表示级联删除,依赖于这张表的也将被删除,例如参考这张表的外键所在的表也将被删除。
  • restrict,表示如果有参考这张表的,在删除时候该条指令会被拒绝。默认restrict删除。

数据查询

# 大体查询语句框架
SELECT [ALL | DISTINCT]<目标表达式>							# 表示查询结果需要的字段
[, <目标表达式>]							# 如果有多个字段,逗号进行隔开
FROM <表或视图> [, 表或者视图]			# 从哪里查询数据
[WHERE <条件表达式>]						# 条件是什么
[GROUP BY <列名1> [HAVING <条件表达式>]]	# 是否需要进行分组
[ORDER BY <列名2> [ASC|DESC]]			# 结果是否需要进行排序,对那个字段进行排序
  • distinct 与 ALL 区别在于查询结果是否消除重复行,all显示所有,不消除重复行,结果有几个就有几个。distinct会将查询结果向同行只显示一行。
  • [not] between and 表示在什么之间,包括两个边界。
  • [not] in <值表> 这个字段值是否在这个值表当中
  • 例如:where Sdept in (‘cs’, ‘ma’, ‘sse’)
  • [not] like ‘<匹配串>’ [ESCAPE ‘<换码字符>’]
  • 匹配串中可以使用占位符:%表示任意长度的字符串,下划线_只占单个字符。
  • 如果本来就有%或者_需要\进行转义
  • AND OR 用来连接多个查询条件,AND优先级高于OR
  • ORDER BY 排序, ASC 升序 DESC 降序

相关内容

热门资讯

安卓系统电脑图片格式 你有没有想过,你的安卓系统电脑里那些美美的图片,它们到底是以什么格式存储的呢?今天,就让我带你一探究...
vivo属于安卓系统还是苹果系... 你有没有想过,手机的世界里,vivo这个品牌是站在安卓的阵营还是苹果的队伍呢?今天,就让我带你一探究...
夏普yunos与安卓系统下载,... 夏天来了,阳光明媚,是不是你也想给你的手机来点清凉呢?今天,就让我带你一起探索一下夏普Yunos与安...
米兔定制系统安卓版,畅享极致体... 你有没有听说过米兔定制系统安卓版?这可是最近在互联网上掀起一阵热潮的新玩意儿!想象你的手机就像是一个...
小米9降到安卓9系统,经典再现 你知道吗?最近小米9这款手机可是火了一把,因为它竟然降级到了安卓9系统!是不是觉得有点不可思议?别急...
安卓个人系统账号是什么 你有没有想过,为什么你的手机里那么多应用,却总是感觉少了点什么?没错,那就是安卓个人系统账号的魅力所...
连城读书安卓4.0系统,畅享阅... 你有没有发现,最近连城读书的安卓4.0系统升级后,阅读体验简直就像开挂了一样?让我来给你细细道来,看...
安卓复制系统分区文件,基于安卓... 你有没有遇到过这种情况:手机里的重要文件突然不见了,或者是想备份一些系统分区文件,却发现安卓系统里的...
电视开机安卓系统坏了,探究原因... 最近家里那台老电视又闹起了别扭,一开机就显示安卓系统坏了,真是让人头疼。这不,我赶紧上网搜罗了一番,...
鸿蒙系统会被入侵吗安卓,守护智... 你有没有听说最近鸿蒙系统火得一塌糊涂?没错,就是那个华为自主研发的操作系统。不过,随着它的普及,人们...
现在电视机安卓系统,安卓系统引... 亲爱的读者们,你是否还在为家里的老式电视而烦恼?现在,让我带你走进一个全新的世界——搭载安卓系统的现...
什么叫安卓系统服务号码,功能与... 你有没有想过,手机里那些神秘的数字,它们到底是从哪里来的呢?今天,就让我带你一探究竟,揭开安卓系统服...
安卓开源系统后门打不开,解锁安... 安卓开源系统后门打不开?教你如何一步步排查与解决在数字化时代,安卓操作系统以其开源的特性赢得了全球用...
扫码注册安卓系统,便捷高效的用... 你有没有想过,现在的生活真是越来越方便了?一说到方便,那可就不得不说扫码注册这个神奇的小玩意儿了。尤...
小米手机安卓9.0系统,深度解... 你有没有发现,最近小米手机的新鲜事儿可真不少啊!这不,小米手机又推出了搭载安卓9.0系统的最新款,简...
安卓系统是谁创建的,谷歌的创世... 你有没有想过,我们每天离不开的安卓系统,这个让手机、平板、智能手表等设备都能互联互通的小家伙,究竟是...
安卓和wp系统互通吗,探索互通... 你有没有想过,安卓和WP系统之间是不是也能来个“跨界恋”呢?想象你的安卓手机里装满了各种酷炫应用,而...
苹果安卓系统自动更新,安全无忧 你有没有发现,最近你的手机是不是总在偷偷地更新呢?没错,说的就是你,那个陪伴你日夜的手机——无论是苹...
安卓5系统以下的手机,探索安卓... 你手里那台安卓5系统以下的手机,是不是已经陪你走过了不少风风雨雨?别看它现在看起来有点老气横秋,但它...
安卓系统添加布局,基于安卓系统... 你有没有想过,你的安卓手机界面可以变得如此个性化,就像你的衣服一样,独一无二呢?没错,今天就要来聊聊...