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 -- 回忆笔记(二):增删改查,修改表结构,约束,关键字使用,函数,多表联合查询的更多相关文章

  1. Sql Server数据库之四个增删改查

    一.数据库的增删改查 1.新建数据库 create database students on primary ( name="students_data",--主数据文件的逻辑名 ...

  2. MyBatis学习(二)、SQL语句映射文件(2)增删改查、参数、缓存

    二.SQL语句映射文件(2)增删改查.参数.缓存 2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id=" ...

  3. MyBatis学习 之 二、SQL语句映射文件(2)增删改查、参数、缓存

    目录(?)[-] 二SQL语句映射文件2增删改查参数缓存 select insert updatedelete sql parameters 基本类型参数 Java实体类型参数 Map参数 多参数的实 ...

  4. SQL你必须知道的-增删改查与约束

    SQL你必须知道的-增删改查与约束   -- 插入数据    --Insert 语句可以省略表名后的列名,但是不推荐    insert into Class values ('' 高一一班 '', ...

  5. MyBatis学习系列二——增删改查

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...

  6. SQL Server -- 回忆笔记(五):T-SQL编程,系统变量,事务,游标,触发器

    SQL Server -- 回忆笔记(五):T-SQL编程,系统变量,事务,游标,触发器 1. T-SQL编程 (1)声明变量 declare @age int (2)为变量赋值 (3)while循环 ...

  7. Python进阶----数据库的基础,关系型数据库与非关系型数据库(No SQL:not only sql),mysql数据库语言基础(增删改查,权限设定)

    day37 一丶Python进阶----数据库的基础,mysql数据库语言基础(增删改查,权限设定) 什么是数据库:    简称:DataBase ---->DB    数据库即存放数据的仓库, ...

  8. Android SQL语句实现数据库的增删改查

    本文介绍android中的数据库的增删改查 复习sql语法: * 增 insert into info (name,phone) values ('wuyudong','111') * 删 delet ...

  9. MongoDB学习笔记,基础+增删改查+索引+聚合...

    一 基础了解 对应关系 -> https://docs.mongodb.com/manual/reference/sql-comparison/ database -> database ...

随机推荐

  1. python练习六—简单的论坛

    进行简单的web应用之后,接下来就应该学习python连接数据库,这个练习就是在上个练习的基础上将信息保存到数据库,这个联系也没有什么特别的,有之前java web的经验的话,很好理解,主要还是一个M ...

  2. SQL Server 2008 R2 下如何清理数据库日志文件

    废话不多说,直接上代码,清理后日志文件为1M USE [master] GO ALTER DATABASE [数据库名] SET RECOVERY SIMPLE WITH NO_WAIT GO ALT ...

  3. vue_drf之实现短信验证码

    一.需求 1,需求 我们在做网站开发时,登录页面很多情况下是可以用手机号接收短信验证码,然后实现登录的,那我们今天就来做一做这一功能. 伪代码: 进入登录页面,点击短信登录 输入手机号码,点击获取验证 ...

  4. mybatis是如何防止SQL注入的

    mybatis是如何防止SQL注入的 1.首先看一下下面两个sql语句的区别: <select id="selectByNameAndPassword" parameterT ...

  5. 数据可视化 seaborn绘图(1)

    seaborn是基于matplotlib的数据可视化库.提供更高层的抽象接口.绘图效果也更好. 用seaborn探索数据分布 绘制单变量分布 绘制二变量分布 成对的数据关系可视化 绘制单变量分布 se ...

  6. Ubuntu使用(一)——常用命令与软件安装配置

    1.安装输入法 2.配置JDK 3.eclipse 3.1 eclipse启动错误 修改eclipse.init的配置,主要加-vm以及下面的jre路径,路径前别留空格 之前因为加了空格,一直找不到原 ...

  7. 第一册:lesson ninety-five。

    原文: tickets,please. Two return tickets to London please. What time will the next train leave? At nin ...

  8. C#工具类:使用SharpZipLib进行压缩、解压文件

    SharpZipLib是一个开源的C#压缩解压库,应用非常广泛.就像用ADO.NET操作数据库要打开连接.执行命令.关闭连接等多个步骤一样,用SharpZipLib进行压缩和解压也需要多个步骤.Sha ...

  9. EF(EntityFramework)与mysql使用,错误终极解决方案

    我昨天写了好多篇跟mysql有关的错误,但是在今天我发现好像所有的问题都是一个原因引起的: 版本问题,我原先使用的是MySql.Data.Entity.EF6(版本号:6.10.5),今天我换成6.9 ...

  10. asp.net-服务器控件-Label-20180329

    主要用于展示静态文本.可使用代码改变Label控件属性. Label常用属性 ID:控件名称 Text:显示的文本 Width:宽度设置 BackColor:背景颜色 BorderColor:边框颜色 ...