SQLServer 学习笔记之超详细基础SQL语句 Part 2

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介: SQLServer 学习笔记之超详细基础SQL语句 Part 2

Sqlserver学习笔记


-----------------------接Part 1-------------------

建立如下数据表

CREATETABLE std_table1

(

  学号        INTPRIMARYKEYIDENTITY,

  姓名        CHAR(20)NOTNULL,

  专业方向     VARCHAR(10)NOTNULL,

  系部代码     CHAR(2)NOTNULL,

  备注        VARCHAR(50)

)

 

CREATETABLE系部

(

  系部代码CHAR(6)NOTNULLPRIMARYKEY,

  系部名称VARCHAR(20)NOTNULL,

  系主任      CHAR(8)

)

 

CREATETABLE专业

(

  专业代码CHAR(4)NOTNULLPRIMARYKEY,

  专业名称VARCHAR(20)NOTNULL,

  系部名称CHAR(6)CONSTRAINT fk_wj1 REFERENCES系部(系部代码) 

)

CREATETABLE班级

(

  班级代码CHAR(9)NOTNULLPRIMARYKEY,

  班级名称VARCHAR(20),

  专业代码CHAR(4)CONSTRAINT fk_wj2 REFERENCES专业(专业代码),

  系部代码CHAR(6)CONSTRAINT fk_wj3 REFERENCES系部(系部代码),

  备注    CHAR(50)

)

 

CREATETABLE学生

(

  学号    CHAR(12)NOTNULLPRIMARYKEY,

  姓名    CHAR(8)NOTNULL,

  出生年月datetime,--注意这里只能用小写

  入学日期datetime,

  班级代码CHAR(9)CONSTRAINT fk_wj4 REFERENCES班级(班级代码),

  系部代码CHAR(6)CONSTRAINT fk_wj5 REFERENCES系部(系部代码),

  专业代码CHAR(4)CONSTRAINT fk_wj6 REFERENCES专业(专业代码)

)


 

 

注意以上表的删除顺序:先学生再班级再专业再系部,,,

9.数据的添加

格式:

INSERT[INTO]表名(列名1,列名2,……)VALUES(value1,value2,……)

9.1vavlues的插入

示例:

前提:“学号列为标识增量

 

 

 

1--往表std_table中添加一条数据[注意:学号设为了增量标识]

INSERTINTO std_TABLE VALUES('zs','计算机','01','没有')

 

2--往表std_table中的某些列插入一条数据

INSERTINTO std_TABLE(名称,专业方向,系部代码)

VALUES('张三','数学','04')

 

9.1.2values的插入

--往表std_table中插入一批数据

INSERTstd_TABLE(姓名,专业方向,系部代码)

SELECT姓名,专业方向,系部代码

FROMstd_TABLE

 

10数据查询

10.1--查询表std_table中前10行记录

SELECTTOP 10系部代码,专业方向

FROMstd_table

 

10.2--查询表std_table前面P的记录结果

SELECTTOP 50 PERCENT系部代码,专业方向

FROMstd_table

 

10.3--查询表std_table中姓名为k,或者j开头的的所有记录

SELECT*FROM std_table

WHERE姓名LIKE'[kj]%'

 

10.4--查询表std_table中姓名不为k,或者j开头的的所有记录

SELECT*FROM std_table

--WHERE姓名NOT LIKE '[kj]%'

WHERE姓名LIKE'![kj]%'

 

11.用查询结果新生新表【类比插入INSERT就好理解了】

格式:SELECT * INTO新表表名from表名

示例:

SELECT*INTO new_table FROM std_table

SELECT*FROM new_table

 

SELECT*INTO new_table2 FROM std_table

WHERE姓名='zs'

SELECT*FROM new_table2

 

SELECT学号,姓名INTOnew_table1 FROM std_table

SELECT*FROM new_table1

SELECT学号,姓名,专业方向,系部代码,备注

FROMstd_table

 

下面的例子会创建一个名为"Persons_Order_Backup"的新表,其中包含了从PersonsOrders两个表中取得的信息

SELECTPersons.LastName,Orders.OrderNo

INTOPersons_Order_Backup

FROMPersons

INNER JOINOrders

ONPersons.Id_P=Orders.Id_P

 

12.把查询结果新生新表,且把新表为临时表(下面#new_table变成了系统数据库下的临时表)

SELECT*INTO #new_table FROM std_table

SELECT*FROM #new_table

 

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
2月前
|
SQL 存储 关系型数据库
关系型数据库SQLserver基本 SQL 操作
【7月更文挑战第28天】
33 4
|
1月前
|
SQL 运维 监控
SQL Server 运维常用sql语句(二)
SQL Server 运维常用sql语句(二)
21 3
|
1月前
|
SQL XML 运维
SQL Server 运维常用sql语句(三)
SQL Server 运维常用sql语句(三)
12 1
|
1月前
|
SQL 关系型数据库 MySQL
SQL数据库和 SQLserver数据库
【8月更文挑战第19天】SQL数据库和 SQLserver数据库
45 2
|
28天前
|
SQL 关系型数据库 MySQL
SQL Server、MySQL、PostgreSQL:主流数据库SQL语法异同比较——深入探讨数据类型、分页查询、表创建与数据插入、函数和索引等关键语法差异,为跨数据库开发提供实用指导
【8月更文挑战第31天】SQL Server、MySQL和PostgreSQL是当今最流行的关系型数据库管理系统,均使用SQL作为查询语言,但在语法和功能实现上存在差异。本文将比较它们在数据类型、分页查询、创建和插入数据以及函数和索引等方面的异同,帮助开发者更好地理解和使用这些数据库。尽管它们共用SQL语言,但每个系统都有独特的语法规则,了解这些差异有助于提升开发效率和项目成功率。
110 0
|
1月前
|
SQL 运维 Oracle
SQL Server 项目中 SQL 脚本更新、升级方式,防止多次重复执行
SQL Server 项目中 SQL 脚本更新、升级方式,防止多次重复执行
29 0
|
8天前
|
SQL 数据库
数据库数据恢复—SQL Server数据库报错“错误823”的数据恢复案例
SQL Server附加数据库出现错误823,附加数据库失败。数据库没有备份,无法通过备份恢复数据库。 SQL Server数据库出现823错误的可能原因有:数据库物理页面损坏、数据库物理页面校验值损坏导致无法识别该页面、断电或者文件系统问题导致页面丢失。
52 12
数据库数据恢复—SQL Server数据库报错“错误823”的数据恢复案例
|
1月前
|
SQL 数据库 数据安全/隐私保护
SQL Server数据库Owner导致事务复制log reader job无法启动的解决办法
【8月更文挑战第14天】解决SQL Server事务复制Log Reader作业因数据库所有者问题无法启动的方法:首先验证数据库所有者是否有效并具足够权限;若非,使用`ALTER AUTHORIZATION`更改为有效登录名。其次,确认Log Reader使用的登录名拥有读取事务日志所需的角色权限。还需检查复制配置是否准确无误,并验证Log Reader代理的连接信息及参数。重启SQL Server Agent服务或手动启动Log Reader作业亦可能解决问题。最后,审查SQL Server错误日志及Windows事件查看器以获取更多线索。
|
3天前
|
SQL 关系型数据库 MySQL
创建包含MySQL和SQLServer数据库所有字段类型的表的方法
创建一个既包含MySQL又包含SQL Server所有字段类型的表是一个复杂的任务,需要仔细地比较和转换数据类型。通过上述方法,可以在两个数据库系统之间建立起相互兼容的数据结构,为数据迁移和同步提供便利。这一过程不仅要考虑数据类型的直接对应,还要注意特定数据类型在不同系统中的表现差异,确保数据的一致性和完整性。
18 4
|
17天前
|
SQL 存储 数据管理
SQL Server数据库
SQL Server数据库
35 11