SQL整理

SQL 对大小写不敏感!

一、对数据的操作

实现功能分类:

  1. 增:

    1.1 表存在,插入栏位:

    //插入新的行(按栏位的顺序插入)

      INSERT INTO Table_1 VALUES ('bly',23,'girl')

      //指定栏位插入

      INSERT INTO Table_1 (name,address) VALUES ('bbbb','cccc')

      //将表2表中的数据都复制新增至表1中

   INSERT INTO Table_1  SELECT * FROM Table_2

    1.2 表不存在

      //先建立表3,再将表1中的指定栏位插入新表

  SELECT name,address INTO Table_3 FROM Table_1

  2.  删

    2.1 DELETE FROM Table_1  //删除表1表中所有数据(逐条删除,速度慢)

    2.2 TRUNCATE TABLE Table_1  //清空表1表的数据(一次性删除所有,速度快)

      注:delete、truncate、drop区别

删除XXX

应用范围

格式

表和索引所占空间

delete

数据

table&&view

DELETE  FROM  table

不会减少

truncate

数据

table

TRUNCATE  TABLE  table

恢复初始大小

drop

DROP  TABLE  table

表占空间全部释放

3           改

3.1 UPDATE Table_1 SET gender='boy' WHERE name='bbbb'

4           查

4.1          SELECT * FROM Table_1 WHERE gender='boy'

4.2          SELECT * FROM Table_1

4.3          SELECT TOP 50 PERCENT name,SUM(price) FROM Table_1

GROUP BY name

Having SUM(price)>100

ORDER BY SUM(price)执行顺序:

  1. FROM
  2. WHERE
  3. GROUP  BY  分组。一般和聚合函数一起用。
  4. HAVING              查询条件。WHERE 关键字无法与合计函数一起使用
  5. SELECT                查询
  6. DISTINCT           去重
  7. ORDER                排序
  8. TOP 10 (PERCENT) 前10(%)

4.4          模糊查询

‘%’多字符模糊匹配。如:’周%’,’%超’

‘_’一个字符模糊匹配。如:’周_’,’_超’

SELECT * FROM Table_1 WHERE name LIKE '%小%'

SELECT * FROM Table_1 WHERE name NOT LIKE '_超'

其他操作符

1          AND

SELECT * FROM Table_1 WHERE (name='bly' AND gender='girl')

2          OR

SELECT * FROM Table_1 WHERE (name='bly' OR name='zxl')

3          IN

IN 操作符允许我们在 WHERE 子句中规定多个值。

SELECT * FROM Table_1 WHERE name IN ('bly','zxl')  //结果同上OR的结果

4          BETWEEN…AND…

包括前,不包括后

     SELECT * FROM Table_1 WHERE price BETWEEN 50 AND 100 (50<=X<100)

5          JOIN

A B 为例

A                                                                                              B

                     

5.1         内连接 INNER JOIN 则为交集AB

SELECT * FROM Table_1

INNER JOIN Table_2

ON Table_1.name = Table_2.name

5.2         外连接 FULL OUTER JOIN则为并集AB

SELECT * FROM Table_1

FULL OUTER JOIN Table_2

ON Table_1.name = Table_2.name

5.3         左连           LEFT JOIN则为A表全显示,B表没数据的NULL显示

SELECT * FROM Table_1

LEFT OUTER JOIN Table_2

ON Table_1.name = Table_2.name

    

5.4         右连           RIGHT JOIN 则为 B表全显示,A表没数据的NULL显示

SELECT * FROM Table_1

RIGHT JOIN Table_2

ON Table_1.name = Table_2.name

5.5         CROSS JOIN  为A表和B表的数据N*M

SELECT * FROM Table_1

CROSS JOIN Table_2

添:

A.   A表有,B表没有

SELECT * FROM Table_1

FULL OUTER JOIN Table_2

ON Table_1.name = Table_2.name

WHERE Table_2.name IS NULL

B.   A表、B表共有以外的

SELECT * FROM Table_1

FULL OUTER JOIN Table_2

ON Table_1.name = Table_2.name

WHERE Table_1.name IS NULL OR Table_2.name IS NULL

6          UNION

     合并两个或多个 SELECT 语句的结果集。

UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同。

SELECT * FROM Table_3 WHERE name='123'

UNION

SELECT * FROM Table_1 WHERE name='paulinka'

6.1          选取不同的值

SELECT name FROM Table_3

UNION

SELECT name FROM Table_1

6.2   允许重复的值

SELECT name FROM Table_3

UNION ALL

SELECT name FROM Table_1

函数:

  1.  AVG()平均值
  2. SUM()和
  3. COUNT()总数
  4. LEN()长度
  5. UCASE()大写
  6. LCASE()小写
  7. ROUNDAX)显示A栏位数据小数点后X
  8. GETDATE()获取时间
  9. MIN()最小值
  10. MAX()最大值

二、对表的操作

 1    新建表

     1.1       插入数据同时创建表

           SELECT * INTO Table_3 FROM Table_1

1.2    新建空表

CREATE TABLE Table_4 (

name nvarchar(30),

age int

)

2          删除表

DROP TABLE Table_3

3          修改表

3.1       添加栏位

ALTER TABLE Table_1 ADD price int

3.2       删除栏位

                        ALTER TABLE Table_2 DROP COLUMN name

SQL学习整理的更多相关文章

  1. SQL学习整理_1

    数据库是保存表和其他相关SQL结构的容器. 列是存储在表中的一块同类型数据. 行是一组能够描述某个事物的列的集合. SQL不区分大小写,但建议命令采用大写,表名采用小写,便于读写. 建立数据库 CRE ...

  2. SQL学习整理_2

    字符串处理,字符串函数不会改变存储在表中的数据内容,他们只是把函数结果当成查询结果返回. 1. SELECT right(name,2) FROM my_list   --从my_list列表中取出n ...

  3. 一个项目涉及到的50个Sql语句(整理版)

    /* 标题:一个项目涉及到的50个Sql语句(整理版) 说明:以下五十个语句都按照测试数据进行过测试,最好每次只单独运行一个语句. */ --1.学生表Student(S,Sname,Sage,Sse ...

  4. 基于实际项目的SQL学习总结

    青云   随笔 - 2, 文章 - 0, 评论 - 1, 引用 - 0 一个项目涉及到的50个Sql语句(整理版) /* 标题:一个项目涉及到的50个Sql语句(整理版) 说明:以下五十个语句都按照测 ...

  5. js数组学习整理

    原文地址:js数组学习整理 常用的js数组操作方法及原理 1.声明数组的方式 var colors = new Array();//空的数组 var colors = new Array(3); // ...

  6. TweenMax学习整理--特有属性

    TweenMax学习整理--特有属性   构造函数:TweenMax(target:Object, duration:Number, vars:Object) target:Object -- 需要缓 ...

  7. HttpClient学习整理

    HttpClient简介HttpClient 功能介绍    1. 读取网页(HTTP/HTTPS)内容    2.使用POST方式提交数据(httpClient3)    3. 处理页面重定向    ...

  8. !!对python列表学习整理列表及数组详细介绍

    1.Python的数组分三种类型:(详细见 http://blog.sina.com.cn/s/blog_6b783cbd0100q2ba.html) (1) list 普通的链表,初始化后可以通过特 ...

  9. Java设计模式(学习整理)---命令模式

    设计模式之Command(学习整理) 1.Command定义 不少Command模式的代码都是针对图形界面的,它实际就是菜单命令,我们在一个下拉菜单选择一个命令时,然后会执行一些动作. 将这些命令封装 ...

随机推荐

  1. python jieba分词(添加停用词,用户字典 取词频

    中文分词一般使用jieba分词 1.安装 pip install jieba 2.大致了解jieba分词 包括jieba分词的3种模式 全模式 import jieba seg_list = jieb ...

  2. 【剑指Offer】49、把字符串转换成整数

      题目描述:   将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数. 数值为0或者字 ...

  3. 重置root管理员密码(RedHat、CentOS、Fedora)

    重启Linux系统主机并出现引导画面时,按下键盘上的e键进入内核编辑界面. 在Linux16参数这行后面追加"rd.break"参数,然后按下Ctrl+x组合键来运行修改后的内核程 ...

  4. [CodeForces]908D New Year and Arbitrary Arrangement

    设状态f[i][j]表示有i个a,j个ab的期望 发现如果i+j>=k的话就再来一个b就行了. #include <iostream> #include <cstdio> ...

  5. 继续聊WPF——Expander控件(1)

    这个控件最实用的地方,就是做导航栏. <StackPanel Margin="20,20" Width="100" Height="460&qu ...

  6. Solr数据不同步

    Solr配置了集群,本地有253和254,2个独立的Solr服务.  同一个页面的图片,刷新2次,图片地址不一样,最后查明,后台数据源Solr1和Solr2的数据不一致.    第1步推测:本地缓存, ...

  7. 洛谷 P2144 BZOJ 1003 [FJOI2007]轮状病毒

    题目描述 轮状病毒有很多变种.许多轮状病毒都是由一个轮状基产生.一个n轮状基由圆环上n个不同的基原子和圆心的一个核原子构成.2个原子之间的边表示这2个原子之间的信息通道,如图1. n轮状病毒的产生规律 ...

  8. 0926mysql join的原理

    转自 http://www.cnblogs.com/shengdimaya/p/7123069.html MySQL JOIN原理   先看一下实验的两张表: 表comments,总行数28856 表 ...

  9. codevs——T2894 Txx考试

    http://codevs.cn/problem/2894/  时间限制: 1 s  空间限制: 32000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Descri ...

  10. A - 敌兵布阵(HDU 1166)

    A - 敌兵布阵 HDU - 1166 思路:线段树单点修改+区间查询. #include<cstdio> #include<cstring> #include<iost ...