SQL学习整理

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

原文地址:https://www.cnblogs.com/paulinka/p/7772483.html

时间: 2024-10-04 17:51:06

SQL学习整理的相关文章

SQL学习整理_1

数据库是保存表和其他相关SQL结构的容器. 列是存储在表中的一块同类型数据. 行是一组能够描述某个事物的列的集合. SQL不区分大小写,但建议命令采用大写,表名采用小写,便于读写. 建立数据库 CREATE DATABASE hf_test 新建数据表 CREATE TABLE test_list1 ( list1_name VARCHAR(10) NOT NULL DEFAULT **  PRIMARY KEY IDENTITY(1,1), list1_type VARCHAR(6), ) /

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

/*标题:一个项目涉及到的50个Sql语句(整理版)作者:爱新觉罗.毓华(十八年风雨,守得冰山雪莲花开)时间:2010-05-10地点:重庆航天职业学院说明:以下五十个语句都按照测试数据进行过测试,最好每次只单独运行一个语句.问题及描述:--1.学生表Student(S#,Sname,Sage,Ssex) --S# 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别--2.课程表 Course(C#,Cname,T#) --C# --课程编号,Cname 课程名称,T# 教师

Oracle之PL/SQL学习笔记

自己在学习Oracle是做的笔记及实验代码记录,内容挺全的,也挺详细,发篇博文分享给需要的朋友,共有1w多字的学习笔记吧.是以前做的,一直在压箱底,今天拿出来整理了一下,给大家分享,有不足之处还望大家批评指正. PL/SQL定义:PL/SQL是由Oracle开发,专门用于Oracle的程序设计语言. PL---Procedural Language. SQL—Structure QueryLanguage.PL/SQL包括过程化语句和SQL语句     PL/SQL的单位:块. 一个块中可以嵌套

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

/* 标题:一个项目涉及到的50个Sql语句(整理版) 说明:以下五十个语句都按照测试数据进行过测试,最好每次只单独运行一个语句. */ --1.学生表Student(S,Sname,Sage,Ssex) --S 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别 --2.课程表 Course(C,Cname,T) --C --课程编号,Cname 课程名称,T 教师编号--3.教师表 Teacher(T,Tname) --T 教师编号,Tname 教师姓名 --4.成绩表

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

青云 随笔 - 2, 文章 - 0, 评论 - 1, 引用 - 0 一个项目涉及到的50个Sql语句(整理版) /* 标题:一个项目涉及到的50个Sql语句(整理版) 说明:以下五十个语句都按照测试数据进行过测试,最好每次只单独运行一个语句. */ --1.学生表Student(S,Sname,Sage,Ssex) --S 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别 --2.课程表 Course(C,Cname,T) --C --课程编号,Cname 课程名称,T 教

Oracle之PL/SQL学习笔记之触发器

Oracle之PL/SQL学习笔记之触发器 触发器是许多关系数据库系统都提供的一项技术.在ORACLE系统里,触发器类似过程和函数,都有声明,执行和异常处理过程的PL/SQL块. 触发器在数据库里以独立的对象存储,它与存储过程和函数不同的是,存储过程与函数需要用户显示调用才执行,而触发器是由一个事件来启动运行. 即触发器是当某个事件发生时自动地隐式运行.并且,触发器不能接收参数.所以运行触发器就叫触发或点火(firing).ORACLE事件指的是对数据库的表进行的INSERT. UPDATE及D

ijwmh1-2-以前学习整理出来的学习内容--什么是变量1整型变量

崧闱旭 ijwmh1-2-以前学习整理出来的学习内容--什么是变量1整型变量

java中反射学习整理

转载请注明:http://blog.csdn.net/j903829182/article/details/38405735 反射主要是指程序可以访问,检测和修改它本身的状态或行为的一种能力. java中反射是一种强大的工具,它能够创建灵活的代码,这些代码可以在运行时装载,无须在组件之间进行链接.反射允许在编写与执行时,使程序能够接入到jvm中的类的内部信息,而不是源代码中选定的类协作的代码.这使反射成为构建灵活应用代码的主要工具.需要注意的是,如果使用不当,反射的成本会很高. package

AJAX学习整理二之简单实例

做了几个简单的实例,加载txt文本内容.加载xml文件内容,把xml文本内容转换成html表格显示.废话不多说,直接贴代码: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/html"> <head>     <title>通过ajax获取文本内容</title>     <meta charset="utf-8">     <scr