四个基础语法
1. insert into 表名 (列名) [values] 值列表
insert into 表名 values 值列表
【扩展】插入多行:
1. insert into <表名> (列名)
select 列名
from <源表名>

2. select 列名
into <表名>
from <源表名>
【注】创建表,复制列名的结构及数据到新表中,但是,这个SQL语句只能使用一次

3. insert into <表名> (列名)
select 值列表 union
select 值列表

2. delete [from] 表名 [where条件]

3. update 表名 set 列名=值 , 列名2=值2 [where条件]

4. select 列名 from 表名 [where 条件]

多表查询:
  内连接(inner join ):
    select 表1.列名,表2.列名 from 表名1 as 表1 inner join 表名2 as 表2
    on 表1.字段名=表2.字段名
    inner join 表名3 as 表3
    on 表1.字段名=表3.字段名

  还可以用另一种写法

    select 表1.列名,表2.列名 from 表名1 as 表1,表名2 as 表2,表名3 as 表3

    where 表1.字段名=表2.字段名

    and  表1.字段名=表3.字段名

  外连接:
    左外:
      select 表1.列名,表2.列名 from 表名1 as
      表1 left outer join 表名2 as 表2
      on 表1.字段名=表2.字段名
    右外:
      select 表1.列名,表2.列名 from 表名1 as
      表1 right outer join 表名2 as 表2
      on 表1.字段名=表2.字段名

  其它知识点

     1. 模糊查询三种方式
      第一种:select 列名 from 表名 where 列名 like '表达式'
      /*
      常见通配符有以下四种:
        _ : 一个字符
        % : 任意长度的字符
        []:区间内的字符
        [^]: 不区间内的字符
        */
      第二种:select 列名 from 表名 where 列名 in (值1,值2)
      第三种:select 列名 from 表名 where 列名 between 值1 and 值2

      【注】:值2不大小于值1

    2. 判断是否为空
      空: 列名 is null or 列名=''
      不为空: 列名 not is null and 列名!=''

    3. 分组(group by...having)
      select 列名(group by 的列名,或者函数) from 表名
      where [条件]
      group by 列名
      having 条件
      order by 排序[asc|desc]

函数

  1. 聚合函数
    SUM(列名):和
    MAX(列名):最大值
    MIN(列名):最小值
    AVG(列名):平均值
    COUNT(列名):列数

    聚合函数是求不为空的个数、值、或者和

  2. 日期:当前日期:getdate()
    datediff(日期部分,日期1,日期2):求日期部分的差
    dateadd(日期部分,增加值,指定日期)
    datepart(日期部分,指定日期)
    datename(日期部分,指定日期)

  3. 字符串函数

    a. charindex(寻找的字符,搜索列[,起始位置]);
      在一段字符中搜索字符或字符串,返回起始位置,(注:起始位置从1开始,如果没有找到返回0)
      e.g select * from Student where charindex('金',StudentName)>0
    b. len(字符串|列名):返回字符串长度
      select len('hello world'); 返回11
    c. upper(字符串|列名):把传递的值转换成大写
      select upper('hello world'); HELLO WORLD
    d. ltrim(字符串|列名):去字符串左边的空格
      rtrim(字符串|列名):去字符串右边的空格
      e.g:select ltrim(' hello world ');
        select rtrim(' hello world ');
    e. right(字符串,长度):
      从字符串右边返回指定数目的字符
     left(字符串,长度)
      从字符串左边返回指定数目的字符
    f. replace(待搜索字符,待查询字符,替换用的字符)
      替换一个字符串中的字符
      e.g select replace('hello world','hello','hi');结果hi world

SQL 基本知识的更多相关文章

  1. [SQL] SQL 基础知识梳理(一)- 数据库与 SQL

    SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...

  2. [SQL] SQL 基础知识梳理(二) - 查询基础

    SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...

  3. [SQL] SQL 基础知识梳理(三) - 聚合和排序

    SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...

  4. [SQL] SQL 基础知识梳理(四) - 数据更新

    SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...

  5. [SQL] SQL 基础知识梳理(五) - 复杂查询

    SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...

  6. [SQL] SQL 基础知识梳理(六)- 函数、谓词、CASE 表达式

    SQL 基础知识梳理(六)-  函数.谓词.CASE 表达式 目录 函数 谓词 CASE 表达式 一.函数 1.函数:输入某一值得到相应输出结果的功能,输入值称为“参数”,输出值称为“返回值”. 2. ...

  7. [SQL] SQL 基础知识梳理(七)- 集合运算

    SQL 基础知识梳理(七)- 集合运算 目录 表的加减法 联结(以列为单位) 一.表的加减法 1.集合:记录的集合(表.视图和查询的执行结果). 2.UNION(并集):表的加法 -- DDL:创建表 ...

  8. PySpark SQL 相关知识介绍

    title: PySpark SQL 相关知识介绍 summary: 关键词:大数据 Hadoop Hive Pig Kafka Spark PySpark SQL 集群管理器 PostgreSQL ...

  9. 常见SQL语句和SQL基础知识

    引自:http://blog.csdn.net/u012467492/article/details/46790205 SQL语句考察(一) 1.查询出每门课都大于80 分的学生姓名 name   k ...

  10. 031医疗项目-模块三:药品供应商目录模块——供货商药品目录查询功能----------sql补充知识

    这个补充知识有一个点很有必要,视屏上的老师提出一点: 内链接关联查询: 如果表A和表B有一个外键关联 ,可以通过外键进行内链接查询 select dictinfo.*, dicttype.typena ...

随机推荐

  1. JS中循环绑定遇到的问题及解决方法

    本文是原创文章,如需转载,请注明文章出处 在工作中,有时会有这样的需求:在一个页面上添加了6个按钮,然后分别为他们绑定点击事件监听器,当点击按钮1时,输出1,当点击按钮2时,输出2. 循环绑定代码如下 ...

  2. MySQL学习记录--操作时间数据

    1.返回日期的时间函数 date_add() : 可以为指定日期增加/减少任意一段时间间隔.下面举例将当前日期增加一个月和减少一个月 mysql month) as add_one_month; +- ...

  3. 前端MV*框架的意义

    经常有人质疑,在前端搞MV*有什么意义?也有人提出这样的疑问:以AngularJS,Knockout,BackBone为代表的MV*框架,它跟jQuery这样的框架有什么区别?我jQuery用得好好的 ...

  4. [sqoop1.99.6] 基于1.99.6版本的一个小例子

    1.创建mysql数据库.表.以及测试数据mysql> desc test;+-------+-------------+------+-----+---------+------------- ...

  5. arguments.callee的用法

    argument为函数内部对象,包含传入函数的所有参数,arguments.callee代表函数名,多用于递归调用,防止函数执行与函数名紧紧耦合的现象,对于没有函数名的匿名函数也非常起作用.举例如下: ...

  6. Android 常用布局视图

    常用包 http://square.github.io/ EventBus Scroller 滚动 拖拽 # android.support.design.widget.CollapsingToolb ...

  7. Web开发中管理ipad屏幕的方向变化

    Web开发中,我们会遇到在手机垂直或水平视角时展示不同状态的情况.下面我来总结一下检测移动设备方向变化的一些方法. 1 使用javascript 直接看代码: <script type=&quo ...

  8. 我们应当怎样学习HTML和CSS

    目标读者:web前端小白.大神请绕路 学习一门新技术,应当找一本经典入门书,在两三天之内快速翻阅完毕,了解其概貌. 然后再制定一个学习路线图(这个路线图绝大多数情况下非书本目录的顺序),接着遵循学习路 ...

  9. 获取下拉框的文本值和value值

    http://www.cnblogs.com/djgs/p/3691979.html?utm_source=tuicool&utm_medium=referral 现在有一个Id为AreaId ...

  10. javascript数组的方法总结,非常实用的!

    在ES5中,一共有9个Array方法 http://kangax.github.io/compat-table/es5/ 注* 九个方法 Array.prototype.indexOfArray.pr ...