SQL语句基础

SQL语句

SQL分类:

DDL:数据定义语句

create,alter,drop...

DML:数据操作语句

insert(添加记录),update(修改记录中的值),delete(删除记录),select(查询语句(表中))

添加记录:INSERT

语法1:

insert into 表名 (列名1,列名2,...,列名n)

values (值1,值2,...,值n);

语法2:

insert into 表名

values (值1,值2,...,值n);

注意:

列可以按照自己的顺序来写,值必须和列一一对应

主键列:如果设定为自动增长,不指定值,默认从1开始,如果已经有数据,取上一个记录值+1,也可以根据自己需要指定值,如果赋值0或者NULL,也是表示自动增长,建议使用NULL

单表查询:

select 字段,...

from

where 行筛选

group by 分组字段

having 组筛选

order by 列排序

limit m,n取结果中的一部分行;

1.基本查询语句:

select 字段,...,字段

from 表名;

注意:

1.执行流程:from,确定表-->select,确定列

2.如果要查询所有的列,可以用*

3.对于数值,日期时间类型的列可以做算术运算,  +,-,*,/

4.查询的结果称为结果集,由行和列组成

5.在查询时,可以修改结果集中的列名,就是给列取别名:

select 列名或者表达式 [as] 别名,...

from 表名;

6.查询时,可以把多个值拼接到一起,  concat(值1,值2,...,值n)

7.null: 代表的未知的,不确定的,不是一个固定值,一种语义的描述,很特殊

表达式中如果有空值,结果还是空,如果null需要转换成某一个值:

ifnull(列或表达式,特殊值)

列或表达式为空时,结果取特殊值

8.查询去重的结果,利用distinct

select distinct 字段

from 表;

2.查询语句之排序子句:order by

语法:

order by 字段 asc|desc,...,字段 asc|desc;

注意:

1.执行流程:from,确定表-->select,确定列,结果集确定->order by,排序

2.asc:升序,  desc:降序,  如果不指定升降,默认升序

3.如果要按照多个列排序

order by 列1 asc|desc,列2  asc|desc

优先看前面的列,前面的列值相等再看下一个列

3.查询语句之行筛选子句--where

语法:

where 条件表达式

注意:

1.执行流程:from,确定表-->where,行筛选,一行一行筛选->select,列->order by,排序

2.条件运算符

    关系运算符:>,>=,<,<=,=(等于),!=,<>(不等于)

    between...and...: 在...和...之间,闭区间,包含两个端点值

    in(点值,...):在列举的值中存在

    is null:是空的, null代表未知不确定,语义表达

    判断是否是空的,不能用=,无法查询结果,只能用is null

    like:模糊查询

    通配符:_:可以代表任意一个字符            %:可以代表任意个(0,1,多个)字符

    where 列或表达式 like '通配符组合表达式'

    eg:查询名字中包含a  '%a%'

逻辑运算符:

    not,  and,  or

    与或非和Java中一样

    注意:优先级,  not>and>or

    如果判断时,可以利用()改变顺序

    not使用

    not between...and...:

    not in(点值,...):

    is not null:

    not like:

4.limit:取一部分结果

语法:

limit m,n;

注意:

1.执行流程:from->where->select->order by,排序->limit,取一部分结果

2.limit m,n: 

    m:从第m条开始, 计数从0开始计数

    n:共取多少行

    如果从0开始,m可以省略  , limit n

作用:可以实现分页效果

eg:设定一页10条

  一共有105条,需要11页

  第1页:limit 0,10

  第2页:limit 10,10

  第n页:limit (n-1)*10,10

5.查询之分组子句---group by

目的:统计时,把数据分成多块,分别统计

语法:

group by 字段,...

注意:

1.执行流程:from->where,行的筛选->group by,剩下的所有行分组->

select,对每个组做统计,一个组得到一个结果->order by,排序->limit

2.当使用group by分组时,除了查询每组统计结果,建议把分组的列查询出来,这样会更有意义

3.如果查询中涉及到组, select中使用组函数,或者使用了group by子句,不能直接查询普通的列,但可以查询分组的列

4.同时按照多个列分组,多个列值都相等才算作一组

group by 列1,列2...

函数:

mysql中内置了很多函数

单行函数:一个行得到一个结果, ifnull(), concat()

多行函数(组函数):多个行(一个组)得到一个结果, 统计函数,聚合函数

如果所有的数据没有分组,算作一组

聚合函数,组函数:

sum(列或表达式):求和

avg(列或表达式):求平均

max(列或表达式):求最大值

min(列或表达式):求最小值

count(列或表达式):统计个数

注意:

1.组函数,统计是不包括空值

2.sum(),avg()只针对数值型,其它三个可以针对任意类型

3.count()为了统计有多少行,建议统计非空列,主键最合适,还可以用count(*)

4.select中使用组函数,就不能同时查询普通的列或使用单行函数

未完待续......

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,284评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,115评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,614评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,671评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,699评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,562评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,309评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,223评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,668评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,859评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,981评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,705评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,310评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,904评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,023评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,146评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,933评论 2 355

推荐阅读更多精彩内容