SQL Server -- 回忆笔记(二):增删改查,修改表结构,约束,关键字使用,函数,多表联合查询
SQL Server知识点回忆篇(二):增删改查,修改表结构,约束,关键字使用,函数,多表联合查询
1. insert
如果sql server设置的排序规则不是简体中文,必须在简体中文字符串前加N, 为了防止乱码问题
insert into tbUsers(UserName,Age,Email,DepartmentID) values(N'小胡子',26,'xiaohuzi@qq.com',11)
2. update
语法格式: update 表名 set 列名=值 where 条件
update tbUsers set Age=27 where id=1
3. delete
语法格式: delete from 表名 where 条件
delete from tbUsers where id=1
使用delete时需谨慎,注意Where条件的控制,避免多删除数据。如果不加where条件,会将表中的所有数据删除(表中自动编号的列不会回到初始值)。
使用 truncate 也可删除数据,但 truncate 无法根据条件删除,只能全部删除表中数据 (如果表中有identity自动编号的列,自动编号会回到初始值)。
4. select
语法格式:select 列名1,列名2,列名3.... from 表名 where 条件
select UserName,Age,Email from tbUsers where UserName='小胡子'
5. 修改表结构
删除列:
alter table tbUsers drop column Age
增加列:
alter table tbUsers add Age int
修改列:
alter table tbUsers alter column Email varchar(30)
添加主键约束:
alter table tbUsers add constraint pk_Email primary key(Email)
添加非空约束:
alter table tbUsers alter column Email varchar(50) not null
添加唯一约束:
alter table tbUsers add constraint UQ_Email unique(Email)
添加默认约束:
alter table tbUsers add constraint DF_Email default('test@qq.com') for Email
添加检查约束:
alter table tbUsers add constraint CK_Age check(Age>0 and Age<100)
添加外键约束:
alter table tbUsers add constraint FK_Department foreign key (DepartmentID) references department(DepartmentID)
删除约束:
alter table tbUsers drop constraint FK_Department
可以在创建表时就加上约束:
create table tbUsers
(
UserName varchar(20),
Age int check(Age>0 and Age<100),
Email varchar(30) unique,
DepartmentID varchar(50)
)
6. 关键字使用
order by: 排序,放在整个sql语句的最后,升序asc, 降序desc
distinct: 对查询出的整个结果集去除重复
top: 取查询结果集的前多少条记录, 与order by结合使用才有意义
like: 模糊查询( _:表示单个字符,%:表示任意字符,[ ]:表示筛选,范围)
group by: 分组统计,与聚合函数配合使用
between...and: 用于查询介于两个值之间的数据范围内的数据集
7. 聚合函数
sum(): 对表中值求和
count(): 统计指定条件下值的数目
max(): 求最大值
min(): 求最小值
avg(): 求平均值
8. 字符串函数
len(): 获取字符的个数
upper(): 转换大写
lower(): 转换小写
ltrim(): 去掉左边空格
rtrim(): 去掉右边空格
left(): 从左边开始截取
right(): 从右边开始截取
substring(): 可用来截取指定位置字符串
9. 日期函数
getdate(): 取得当前日期
dateadd(): 在某个日期加上指定时间段
datediff(): 在某个日期减去指定时间段
datepart(): 取得日期的某部分
convert(): 把日期转换为新数据类型的通用函数。可以用不同的格式显示日期/时间。
10. 多表联合查询
left join: 左表返回所有的行,即使在右表中没有匹配的行
right join: 右表返回所有的行,即使在左表中没有匹配的行。
union: 使用时 select 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 select 语句中的列的顺序必须相同
union all: 如果允许重复的值,请使用 union all。
11. NULL值的判断
在sql server中,判断是否为 null 值用 is null 或 is not null
SQL Server -- 回忆笔记(二):增删改查,修改表结构,约束,关键字使用,函数,多表联合查询的更多相关文章
- Sql Server数据库之四个增删改查
一.数据库的增删改查 1.新建数据库 create database students on primary ( name="students_data",--主数据文件的逻辑名 ...
- MyBatis学习(二)、SQL语句映射文件(2)增删改查、参数、缓存
二.SQL语句映射文件(2)增删改查.参数.缓存 2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id=" ...
- MyBatis学习 之 二、SQL语句映射文件(2)增删改查、参数、缓存
目录(?)[-] 二SQL语句映射文件2增删改查参数缓存 select insert updatedelete sql parameters 基本类型参数 Java实体类型参数 Map参数 多参数的实 ...
- SQL你必须知道的-增删改查与约束
SQL你必须知道的-增删改查与约束 -- 插入数据 --Insert 语句可以省略表名后的列名,但是不推荐 insert into Class values ('' 高一一班 '', ...
- MyBatis学习系列二——增删改查
目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...
- SQL Server -- 回忆笔记(五):T-SQL编程,系统变量,事务,游标,触发器
SQL Server -- 回忆笔记(五):T-SQL编程,系统变量,事务,游标,触发器 1. T-SQL编程 (1)声明变量 declare @age int (2)为变量赋值 (3)while循环 ...
- Python进阶----数据库的基础,关系型数据库与非关系型数据库(No SQL:not only sql),mysql数据库语言基础(增删改查,权限设定)
day37 一丶Python进阶----数据库的基础,mysql数据库语言基础(增删改查,权限设定) 什么是数据库: 简称:DataBase ---->DB 数据库即存放数据的仓库, ...
- Android SQL语句实现数据库的增删改查
本文介绍android中的数据库的增删改查 复习sql语法: * 增 insert into info (name,phone) values ('wuyudong','111') * 删 delet ...
- MongoDB学习笔记,基础+增删改查+索引+聚合...
一 基础了解 对应关系 -> https://docs.mongodb.com/manual/reference/sql-comparison/ database -> database ...
随机推荐
- Centos7搭建邮件服务器-Postfix+Cyrus-sasl+Courier-authlib+Dovecot+ExtMail+Centos7
1.环境介绍 MTA: Postfix 3.1.4 SASL: Cyrus-sasl 2.1.26 ; Courier-authlib 0.66.1(Cyrus-sasl使用Courier-authl ...
- k8s与云服务器之间服务互访之节点网络打通
一.概述 k8s暴露服务的方式有很多使用ingress.nodeport等,这类比较适用于无状态的服务,对于statefulset部署的有状态的服务,(关于statefulset的介绍参考kubern ...
- SVN不能解锁,报错:没有匹配的可用锁令牌的解决方法
命令行进入到要解锁的目录,执行 svn unlock 要解锁的文档名 进行解锁:若还是打不开锁,就用强制解锁 , svn unlock -f(--force) 要解锁的文档名 也可以通过 svnadm ...
- npm设置和查看仓库源
转载请注明出处:https://www.cnblogs.com/wenjunwei/p/10078460.html 在使用npm命令时,如果直接从国外的仓库下载依赖,下载速度很慢,甚至会下载不下来,我 ...
- LeetCode每天一题之两数之和
这个LeetCode刷题系列的博客权当是为自己记一下笔记吧.博客系列会从LeetCode的第一题开始刷,同时会从零开始学习[因为我就是零/(ㄒoㄒ)/~~].同时,如果有写错的地方,希望大佬们在评论区 ...
- TCP/IP协议学习(一)
一.网络模型 OSI七层模型:自上至下依次是 应用层,表示层,会话层,传输层,网络层,数据链路层,物理层 应用层:具体的应用协议如HTTP.SMTP.FTP.TELNET.DNS等 表示层:针对数据格 ...
- c++选择重载函数
一.函数重载 普通函数重载的关键是参数列表---也称函数特征标.函数参数中有以下情况可以出现重载: 1. 形参个数不同 2. 形参的类型不同 3. 形参的类型和个数都不同 const形参和函数重 ...
- [转]docker 部署 mysql + phpmyadmin 3种方法
本文转自:https://blog.csdn.net/Gekkoou/article/details/80897309 方法1: link # 创建容器 test-mysql (千万别用 mysql: ...
- 【问题】vs IIS破除文件上传限制最全版
今天在测试一下上传文件的时候发现iis和配置存在上传文件大小限制(IIS默认大小30M,最大运行为2g:2147483647),百度了一部分资料有些发布到IIS好使,但是在VS调试中不好使.于是自己不 ...
- [leetcode](4.21)3. 最长重复子串
给定字符串 S,找出最长重复子串的长度.如果不存在重复子串就返回 0. 示例 1: 输入:"abcd" 输出:0 解释:没有重复子串. 示例 2: 输入:"abbaba& ...