SQL Server

SQL Server对大小写不敏感,每条语句末端使用分号。

1.SQL命令

  • SELECT 从数据中提取数据

  • UPDATE 更新数据中的数据

  • DELETE 从数据库中删除数据

  • INSERT INTO 向数据库中插入新数据

  • CREATE DATABASE 创建新数据库

  • ALTER DATABASE 修改数据库

  • CREATE TABLE 创建新表

  • ALTER TABLE 变更(改变)数据库表

  • DROP TABLE 删除表

  • CREATE INDEX 创建索引(搜索键)

  • DROP INDEX 删除索引

2.语法:

  1. SELECT语句 用于从数据库中抽取数据,结果存储在一个结果表中,称为结果集。

  • SELECT column_name,column_name  FROM  table_name;(抽取指定列)

    SELECT * FROM table_name;(抽取所有列)  
  • SELECT DISTINCT column_name,column_name  FROM table_name;
    SELECT DISTINCT语句用于返回唯一不同的值,没有重复项。
  • SELECT column_name,column_name FROM table_name
    WHERE column_name operator value;
    (WHERE子句用于过滤记录)
    WHERE子句中的运算符
  1. AND & OR

  2. ORDER BY 用于对结果集进行排序。

ORDER BY关键字用于对结果集按照一个列或者多个列进行排序,默认按照升序对记录进行排序,如需使用降序,需要使用DESC关键字。

SELECT column_name,column_name FROM table_name
ORDER BY column_name,column_name ASC|DESC;
ASC 表示升序;DESC 表示降序;
  1. INSERT INTO用于向表中插入新记录

  • 不指定要插入数据的列名,只提供被插入的值
    INSERT INTO table_name
    VALUES (values1,values2,values3,...);
    此时需要列出插入行的每一列数据
  • 指定列名及插入的值
    INSERT INTO table_name (column1,column2,column3,...)
    VALUES (value1,value2,value3,...);
  1. UPDATE语句,用于更新表中的记录

UPDATE table_name
SET column1=value1,column2=value2,...
WHERE some_column=some_value;

注意:如果省略WHERE语句,则将会对表中该列所有内容赋该值。

  1. DELETE语句:用于删除表中数据

DELETE FROM table_name
WHERE some_column=some_value;
DELETE FROM table_name;

DELETE * FROM table_name;
在不删除表的情况下删除所有的行,表的结构、属性、索引保持不变。
  1. SELECT TOP语句:用于规定要返回的记录的数目,更适用于拥有数千条记录的大型表

LIMIT, ROWNUM

SELECT TOP number|percent column_name(s)
FROM table_name;
实例:
SELECT * FROM table_name LIMIT NUMBER;
表示,从“table_name”表中选取number条记录。
  1. LIKE操作符:用于在WHERE子句中搜索指定列中的指定模式

SELECT column_name(s)
FROM table_name
WHERE column_name LIKE pattern;
  1. 通配符:可用于替代字符串中的任何其他字符。与LIKE操作符一起使用

通配符 描述
% 替代0个或多个字符
_ 替代一个字符
[charlist] 字符列中的任何单一字符
[^charlist]或[!charlist] 不在字符列中的任何单一字符
%:
SELECT * FROM Websites WHERE url LIKE 'https%';
SELECT * FROM Websites WHERE url LIKE '%OO%';
_:
SELECT * FROM Websites WHERE name LIKE '_oogle';
SELECT * FROM Websites WHERE name LIKE 'G_o_le';
[charlist]:
SELECT * FROM Websites WHERE name REGEXP '^[GFs]';
选取name以“G”、“F”或“s”开始的所有网站
使用REGEXP或NOT REGEXP运算符(或RLIKE和NOT RLIKE)来操作正则表达式。
SELECT * FROM Websites WHERE name REGEXP '^[A-H]';
选取 name 以 A 到 H 字母开头的网站
[^charlist]或[!charlist]:
SELECT * FROM Websites WHERE name REGEXP '^[^A-H]';
选取 name 不以 A 到 H 字母开头的网站.
  1. IN操作符

    SELECT column_name(s)
    FROM table_name
    WHERE column_name IN (value1,value2,...);
  2. BETWEEN操作符

    BETWEEN操作符选取介于两个值之间的数据范围内的值,这些值可以是数值、文本或者日期。

    • BETWEEN

    SELECT column_name(s)
    FROM table_name
    WHERE column_name BETWEEN value1 AND value2;
    • NOT BETWEEN

      如需要显示不在范围内的数据,使用NOT BETWEEN:

    SELECT column_name(s)
    FROM table_name
    WHERE column_name NOT BETWEEN value1 and value2;
    • 带有IN的BETWEEN操作符实例

    SELECT column_name(s)
    FROM table_name
    WHERE (column_name BETWEEN value1 and value2)
    AND column_name IN ('value1', 'value2');

    带有文本值的需要在文本值上加上单引号' '。

  3. SQL别名

    通过使用SQL,可以为表名称或列名称指定别名。基本上,创建别名是为了让列名称的可读性更强。

    • 列的SQL别名语法

    SELECT column_name1 AS alias_name,column_name2 AS alias_name
    FROM table_name;

    可以把多个列合起来作为一个列使用别名语法

    SELECT CONCAT(column_name1,','column_name2,',',column_name3) AS alias_name
    FROM table_name;
    • 表的SQL别名语法

    SELECT column_name(s)
    FROM table_name AS alias_name;
    • 在以下情况中,使用别名用处更大:

      • 在查询中涉及超过一个表

      • 在查询中使用了函数

      • 列名称很长或者可读性差

      • 需要把两个列或者多个列结合在一起

  4. SQL连接(JOIN)

    SQL JOIN用于把来自两个或多个表的行结合起来,基于这些表

其他

  • 文本字段用单引号环绕,数值字段不需要

SQL Server学习内容(一)的更多相关文章

  1. SQL server学习

    慕课网sql server学习 数据库第一印象:desktop--web server--database server** 几大数据库:sql server.oracle database.DB2. ...

  2. SQL server学习(三)T-SQL编程、逻辑控制语句和安全模式

    T-SQL编程 T-SQL编程与C语言类似,只是语法稍有不同而已,总体思想还是没有变化的.多的就不说了,还是从变量开始. 变量也分为全局变量和局部变量,表示方式稍有不同. 局部变量: 局部变量必须以标 ...

  3. SQL Server 学习博客分享列表(应用式学习 + 深入理解)

    SQL Server 学习博客分享列表(应用式学习 + 深入理解) 转自:https://blog.csdn.net/tianjing0805/article/details/75047574 SQL ...

  4. sql server学习路径地址

    联机丛书2005:https://docs.microsoft.com/zh-cn/previous-versions/sql/sql-server-2005/ms130214(v=sql.90) 联 ...

  5. SQL Server 学习系列之六

    SQL Server 学习系列之六 SQL Server 学习系列之一(薪酬方案+基础) SQL Server 学习系列之二(日期格式问题) SQL Server 学习系列之三(SQL 关键字) SQ ...

  6. SQL Server 学习系列之五

    SQL Server 学习系列之五 SQL Server 学习系列之一(薪酬方案+基础) SQL Server 学习系列之二(日期格式问题) SQL Server 学习系列之三(SQL 关键字) SQ ...

  7. SQL Server 学习系列之四(SQL 内幕)

    SQL Server 学习系列之四(SQL 内幕) SQL Server 学习系列之一(薪酬方案+基础) SQL Server 学习系列之二(日期格式问题) SQL Server 学习系列之三(SQL ...

  8. 【SQL Server 学习系列】-- sql 随机生成中文名字

    原文:[SQL Server 学习系列]-- sql 随机生成中文名字 ,) )) -- 姓氏 ,) )) -- 名字 INSERT @fName VALUES ('赵'),('钱'),('孙'),( ...

  9. 【SQL Server学习笔记】Delete 语句、Output 子句、Merge语句

    原文:[SQL Server学习笔记]Delete 语句.Output 子句.Merge语句 DELETE语句 --建表 select * into distribution from sys.obj ...

随机推荐

  1. MySQL事务。

    相关资料:https://zhuanlan.zhihu.com/p/70701037        https://zhuanlan.zhihu.com/p/59061106 一.事务. 1.概念.事 ...

  2. [日常] 使用TCPDUMP和Ethereal抓包分析HTTP请求中的异常情况

    在测试功能的过程中,出现这样一种现象.前端js发起ajax请求后,在浏览器的审查元素网络状态中可以看到status为pending,等15秒以后js会把当前超时的请求取消掉,变成了红色的cancel. ...

  3. 解决N个人过桥时间最短问题(Java版本)

    [问题描述] n个人要晚上过桥,在任何时候最多两个人一组过桥,每组要有一只手电筒.在这n个人中只有一个手电筒能用,因此要安排以某种往返的方式来返还手电筒,使更多的人可以过桥.   注意:每个人的过桥速 ...

  4. QQ第三方登录-python_web开发_django框架

    准备工作 1. 成为QQ互联的开发者 参考链接: <http://wiki.connect.qq.com/%E6%88%90%E4%B8%BA%E5%BC%80%E5%8F%91%E8%80%8 ...

  5. python3.5.3rc1学习五:模块

    #比较大小#name:maxNumber.py#比较两个数大小#C:\Users\Anthony\AppData\Local\Programs\Python\Python36-32\Lib\site- ...

  6. day69_10_14 drf接口框架。

    一.drf框架简介 drf全程是:django-rest framework. 其中涉及的知识点有. 1.接口:什么是接口.restful接口规范 2.CBV生命周期源码 - 基于restful规范下 ...

  7. Python学习笔记2基本语法规则_20170611

    # 1.print 显示示例 print('Hello, World!') 逗号分割变量,输出插入空格 name = 'BB' print('AA', name) # output: >> ...

  8. angular 新建命令

    新建项目:ng new my-app 新建组件 ng g c name //组件名称(深层次参考:https://www.cnblogs.com/mary-123/p/10484648.html) 默 ...

  9. Jupyter Notebook使用

    不论你是刚开始学 Python,还是正在啃数据分析的骨头,对你来说,不断在各种命令行窗口和编辑器里切来切去,或者不断打开各种窗口查看 matplotlib 的输出之类的繁琐操作,一定是家常便饭了.哎呀 ...

  10. 【shell脚本】将三个数字进行升序排序===numSort.sh

    从命令输入三个数字进行升序排序(冒泡排序) 原理:比较两个相邻的元素,将值大的元素交换至右端. 脚本内容: [root@VM_0_10_centos shellScript]# cat numSort ...