建库

CREATE DATABASE 数据库名

ON[PRIMARY]  --默认属于PRIMARY主文件组,可省略

(

NAME='',  --主数据文件的逻辑名 名称

FILEAME='',  --主数据文件的物理名 路径 .mdf 次数据库为.ndf

SIZE=5mb,  --主数据文件初始大小

MASSIZE=100mb,  --主数据文件增长最大值

FILEGROETH=15%  --主数据文件增长率

)

LOG ON

(

NAME='',  --日志文件的逻辑名

FILEAME='',  --日志文件的物理名 .ldf

SIZE=5mb,  --日志文件初始大小

MASSIZE=100mb,  --日志文件增长最大值

FILEGROETH=15%  --日志文件增长率

)

删库  跑路

DROP  DATABASE 数据库名

删表

DROP TABLE 表名

一个表只能有一个主键,主键约束确保了表中的行是唯一的。

表中可以没有主键。

如果两列或多列组合起来唯一的标识每一行,则该主键又称组合键。

外键是对应主键而言的,是子表中对应于主键的列,他的值要求与主表的主键或者唯一键对应。

常用数据类型:

二进制数据:image是C#中的byte[]类型,数量随意。binary数据量限定。

字符串类型:

char//ncher//varcher//nvarcher

text//ntext

varcher(MAX)//nvercher(MAX)

不带n的数据类型,存储英文数字是一个字节,汉子两个字节。带n的则全部两个字节。char(2个字节) nchar(2个字符(4个字节))。

不带n的长度最长8000。带n的最长可以4000。(varcher(MAX)//nvercher(MAX)最大可以四个G,在05版本之前使用text,ntext。)

不带var的表示固定长度(永远占固定的字节,自动补全字节数,浪费空间)。带var的表示可变长度。

时间数据:datetime

插入语句(增)

INSERT INTO 表名 (列名,列名) VALUES ('xx','xx')

删除语句(删)

DELETE FROM 表名

WHERE 条件

删除全部记录:DELETE FROM 表名  --表结构,列,索引等还将存在,自增值依然从大值递增。

删除全部数据:TRUNCATE TABLE 表名    --不能用于有外键的表,表结构,列,索引等还将存在,速度比DELETE语句快。自增值重置。不触发触发器。

修改语句(改)

UPDATE 表名

SET 列名=值,列名=值

WHERE 条件

搜索语句(查)

搜索语句的处理顺序:

FORM 表名

ON

INNER JOIN ...

WHERE 条件

GROUP BY ...

WITH CUBE或WITH ROLLUP

HAVING ...

SELSCT 列名

DISTINCT

ORDER BY ASC/DESC

TOP

排序查询 ORDER BY ASC/DESC

该语句必须,一定放在语句的最后。

分组查询 GROUP BY 列名

当使用了分组语句或聚合函数时,在select列表中不能再包含其他的列名,除非该列名在分组语句中或聚合函数中。

分组后判断条件 HAVING

对分组后的条件筛选必须使用HAVING子句,在GROUP BY句之前可用WHERE。

having可以使用聚合函数,但while不可。

联合结果集 UNION

联合要求多个结果集列的数目相同,列的数据类型兼容。

UNION会去处重复,重新排序。UNION ALL不会,节省性能。

SELECT 表名.列,表名.列 FORM 表名 INNER JOIN 表名 ON 条件    --内连接查询语句,INNER JOIN可简写成JOIN

SELECT 表名.列,表名.列 FORM 表名 LEFT/RIOGHT/FULL OUTER JOIN 表名 ON 条件

--左外链接语句,OUTER可省略,结果集会包括LEFT JOIN所指定的左表的所有行,如果左表行在右表中无匹配,将会填充为空,右连接同理。

--FULL表示完全外链接,结果集会包含左右表的所有行,当某行在另一表中没有匹配行则会包含空值。

查询所有列,去重复数据:SELSCT DISTINCT* FORM 表名

DISTINCT  --针对查询出的结果集去除重复

限制行数查询:SELSCT TOP 5 * FORM 表名 ORDER BY 列名 ASC/DESC

TOP  --常与 ORDER BY 连用,

关于空值查询 NULL

NULL值无法用=和<>来判断,使用IS NULL或者IS NOT NULL。

任何值与 NULL 计算,结果都是NULL。

模糊查询

模糊查询:SELECT 列名 LIKE '%'

_  表示任意单个字符。

%  表示任意多个字符。

【0-9】【a-z】【_】表示筛选范围,^表示排除范围。

[]  转义  ESCAPE '/' 后跟此句代表自定义转义符。

按百分比限制查询:SELSCT TOP 50 PERCENT * FORM 表名

在某个范围查询:SELECT 列名 BETWEEN '' AND ''

在某些值内查询:SELECT 列名 FORM 表名 IN ('','')

聚合函数

聚合函数不统计空值

查询表达式中数值的和:SELECT SUM(列名) FORM 表名 WHERE 条件

查询平均值:SELECT AVG(列名) FORM 表名 WHERE 条件

查询最小值:SELECT MIN(列名) FORM 表名 WHERE 条件

查询最大值:SELECT MAX(列名) FORM 表名 WHERE 条件

查询非空列:SELECT COUNT(列名) FORM 表名 WHERE 条件

类型转换函数

CAST(值 as 数据类型)

CONVERT(数据类型,值)

黑马公开课: http://yun.itheima.com/course/165.html

转载请联系

MSSQL 基础知识与语句笔记的更多相关文章

  1. 《Python编程:从入门到实践》基础知识部分学习笔记整理

    简介 此笔记为<Python编程:从入门到实践>中前 11 章的基础知识部分的学习笔记,不包含后面的项目部分. 书籍评价 从系统学习 Python 的角度,不推荐此书,个人更推荐使用< ...

  2. sql sever 基础知识及详细笔记

    第六章:程序数据集散地:数据库 6.1:当今最常用的数据库 sql  server:是微软公司的产品 oracle:是甲骨文公司的产品 DB2:数据核心又称DB2通用服务器 Mysql:是一种开发源代 ...

  3. MSSQL 基础知识002

    ---启用sa账号 1. 先使用一个windows账号登陆. 2.在数据库实例上面右键,属性,安全性,登录名,sa. 右键,属性. 常规,修改sa的密码. 状态,启用sa账号. 主键的作用: 1.唯一 ...

  4. JavaScript基础知识(学习笔记)

    1.    在JavaScript中所有事物都是对象:字符串.数字.数组.日期等等2.    在JavaScript中,对象是拥有属性和方法的数据3.    属性是与对象相关的值,方法是能够在对象上执 ...

  5. VBA基础知识———常用语句

    语句一:if判断语句 Sub 判断1() '单条件判断 If Range("a1").Value > 0 Then Range("b1") = " ...

  6. .net窗体程序的基础知识及详细笔记

    第一章:初识Windows程序 1.1:第一个wondows程序 1.1.1:认识windows程序 Form1.cs:窗体文件:程序对窗体编写的代码一般都存放在这个文件(还有拖动控件时的操作和布局, ...

  7. java基础知识及详细笔记

    第一章:初识java 1.1.java的概述 ü  什么是计算机程序:计算机按照某种顺序而完成的一系列有序指令的集合. ü  Java的作用:1:安装和运行本机上的桌面程序.2:通过浏览器访问面向in ...

  8. HTML5基础知识及相关笔记

    HTML5基础 1.1HTML文件的基本结构和W3C标准 1.1.1HTML简介 HTML是一种描述网页的语言,一种超文本标记的语言! 1.1.2HTML文件的基本结构 头部(head) 头部是网页的 ...

  9. Linux基础知识_Shell编程笔记

    以下是一些 常用功能 , 基于 centos 6.5 x64 # cp /etc/localtime /etc/localtime.org # rm /etc/localtime # ln -s /u ...

随机推荐

  1. plsql链接数据库配置

    一. 目录结构 D:\install\PLSQL        |-- instantclient_11_2            |-- tnsnames.ora        |-- PLSQL ...

  2. 【bzoj题解】1001 狼抓兔子

    题目描述 现在小朋友们最喜欢"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形:   ...

  3. RabbitMQ--Hello world!(一)

    Introduction RabbitMQ is a message broker. The principal idea is pretty simple: it accepts and forwa ...

  4. python网络编程--线程join和Daemon(守护进程)

    一:什么情况下使用join join([timeout])调用join函数会使得主调线程阻塞,直到被调用线程运行结束或超时. 参数timeout是一个数值类型,用来表示超时时间,如果未提供该参数,那么 ...

  5. Spring框架(管理事务)

    Spring底层使用Transaction事物模板来进行操作.具体操作: 1.service 需要获得 TransactionTemplate 2.spring 配置模板,并注入给service 3. ...

  6. MS-SQL2005服务器登录名、角色、数据库用户、角色、架构的关系

    MS SQL2005对2000进行了很大的改进,而用户关系这部分也变得相当复杂了,很多朋友都对此一知半解!下面,我将把我应用中总结的和大家分享下,先从概念入手,希望对不理解的朋友有点提示. 今天我们要 ...

  7. 在Visio里加上、下标方法

    添加上标:选中要成为上标的文字,ctrl+shift+“=” 添加下标:选中要成为下标的文字,ctrl+“=”

  8. PHP 识别 java 8位 des 加密和 解密方式

    代码及使用说明: <?php /** *PHP 识别 java 8位密钥的加密和解密方式 *@desc 加密方式 通用 */ class DES { var $key; var $iv; //偏 ...

  9. Centos 7.2 安装 Python 3.5(适用于Python 3所有版本安装)

    提示:我们必须不能破坏系统的环境.因为几个关键的应用程序依赖于Python 2.7.5(centos 7默认版本).如果替换了系统的Python环境就会发生很多难以预见的错误,甚至要重装系统. 安装前 ...

  10. 单元测试+内存、SD卡、SP读写+XmlPullParser

    测试: 测试的相关概念 1.根据是否知道源代码分类: 黑盒测试: a - b - c 边值测试 测试逻辑业务 白盒测试: 根据源代码写测试方法 或者 测试用例; 2.根据测试的粒度分类: 方法测试:写 ...