MySQL_入手<二>之删--改--查
接上 上篇文章继续
查询
# 比较运算
# 根据WHERE条件查找数据: = > < >= <= !=
select * from t_hero where age < 30;
# 逻辑判断
# AND : 指定多个条件,所有条件必须满足
select * from t_hero where age > 20 and state='吴';
# OR : 指定多个条件,满足任意一个条件即可
select * from t_hero where age > 20 or state='吴';
# NOT:不满足指定条件,
select * from t_hero where not age > 30;
select 列1,列2,... from 表名;
例:
select id,name from t_hero; 说明:主键列是自动增长,但是在全列插入时需要占位,通常使用0,插入成功后以实际数据为准
全列插入:值的顺序与表中字段的顺序对应
insert into 表名 values(...)
例:
insert into students values(0,'郭靖',1,'蒙古','2015-1-2');
部分列插入:值的顺序与给出的列顺序对应
insert into 表名(列1,...) values(值1,...)
例:
insert into students(name,hometown,birthday) values('黄蓉','桃花岛','2015-3-2');
上面的语句一次可以向表中插入一行数据,还可以一次性插入多行数据,这样可以减少与数据库的通信
全列多行插入:值的顺序与给出的列顺序对应
insert into 表名 values(...),(...)...;
例:
insert into classes values(0,'python'),(0,'linux'),(0,'mysql'),(0,'js');
insert into 表名(列1,...) values(值1,...),(值1,...)...;
例:
insert into students(name) values('杨康'),('杨过'),('小龙女');
删除
delete from 表名 where 条件
例:
delete from students where id=5;
修改
update 表名 set 列1=值1,列2=值2... where 条件
例:
update students set gender=0,hometown='古墓' where id=5;
模糊查询
# 模糊查询 like
# % : 代表任意多个的任意字符
select * from t_hero where name like "%张飞%"; # _ : 代表一个任意字符,如果多个_ 则表示多个任意字符
select *from t_hero where name like "_张飞_";
固定范围查询:
# 范围查询: IN 表示查询的值指定的集合内;
select *from t_hero where age in (30, 45);
# 范围查询:NOT IN 表示查询的字符不在指定的集合内
select *from t_hero where age not in (30, 45);
空值查询
# IS NULL :表示查找数据为空的数据
select *from t_hero where state is null;
# IS NOT NULL: 表示查找非空的数据
select *from t_hero where state is not null;
聚合函数
# count :统计个数,
select count(*) as "年龄大于30的人数"from t_hero where age > 30;
# max:统计某个列里的最大值,比如age
select max(age) as "蜀国的最大年龄"from t_hero where state = "蜀";
# min:统计某个列里的最小值
select min(age) as "魏国的最小年龄" from t_hero where state = "魏";
# sum: 统计某一列的数据之和,as 可以给查出的数据列起别名
select sum(age) as '魏国年龄总和' from t_hero where state = "魏";
# avg:统计某一列数据的平均值
select avg(age) as '魏国年龄平均数' from t_hero where state = "魏";
GROUP BY 分组操作
1. 单独使用:直接对数据进行分组(单独使用没有任何意义)
select * from t_hero group by state;
2. GROUP_CONCAT:对数据进行分组,并通过GOURP_CONCAT() 将指定列数据拼接到一起
select state, group_concat(name) from t_hero GROUP BY state; 3. 聚合函数:对数据进行分组,分组后的数据根据查询语句的聚合函数来统计指定的数据
SELECT gender, sum(age) FROM t_hero GROUP BY gender; 4. HAVING : 限制输出结果(对select 查询的结果进行限制输出):
# having是对最后select 的结果进行限制输出,having的字段必须在select查询的字段里
SELECT state, count(*) as num FROM t_hero GROUP BY state HAVING num >= 3;
SELECT state, count(*) as num FROM t_hero GROUP BY state HAVING state = '蜀';
排序:ORDER BY
# order by 对指定的列进行排序,
# 默认是升序(从小到大), ASC (ascend)
select * from t_hero ORDER BY id;
select * from t_hero ORDER BY id ASC; # DESC 指定为降序(从大到小)
select * from t_hero ORDER BY id DESC; # 配合where条件进行排序
select * from t_hero where state='蜀' and gender='男' ORDER BY age DESC;
MySQL_入手<二>之删--改--查的更多相关文章
- 好用的SQL TVP~~独家赠送[增-删-改-查]的例子
以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化. 本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...
- iOS FMDB的使用(增,删,改,查,sqlite存取图片)
iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...
- iOS sqlite3 的基本使用(增 删 改 查)
iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...
- django ajax增 删 改 查
具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...
- ADO.NET 增 删 改 查
ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访 ...
- MVC EF 增 删 改 查
using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...
- Go语言之进阶篇mysql增 删 改 查
一.mysql操作基本语法 1.创建名称nulige的数据库 CREATE DATABASE nulige DEFAULT CHARSET utf8 COLLATE utf8_general_ci; ...
- oracle 11g 建库 建表 增 删 改 查 约束
一.建库 1.(点击左上角带绿色+号的按钮) 2.(进入这个界面,passowrd为密码.填写完后点击下面一排的Test按钮进行测试,无异常就点击Connect) 二.建表 1-1. create t ...
- Django(十)模型:django模型类对数据库的:增/删/改/查、自关联、管理器、元选项(指定表名)
一.插入.更新和删除 调用一个模型类对象的save方法的时候就可以实现对模型类对应数据表的插入和更新. 调用一个模型类对象的delete方法的时候就可以实现对模型类对应数据表数据的删除. 二.自关联 ...
随机推荐
- AcWing:112. 雷达设备(贪心 + 笛卡尔坐标系化区间)
假设海岸是一条无限长的直线,陆地位于海岸的一侧,海洋位于另外一侧. 每个小岛都位于海洋一侧的某个点上. 雷达装置均位于海岸线上,且雷达的监测范围为d,当小岛与某雷达的距离不超过d时,该小岛可以被雷达覆 ...
- PTA 笛卡尔树
笛卡尔树 (25 分) 笛卡尔树是一种特殊的二叉树,其结点包含两个关键字K1和K2.首先笛卡尔树是关于K1的二叉搜索树,即结点左子树的所有K1值都比该结点的K1值小,右子树则大.其次所有结点的K2关键 ...
- CLion配置Cygwin环境
CLion "download" 跳转到 https://cygwin.com/install.html 下载64位安装程序并安装 国内添加网易镜像 http://mirrors. ...
- FinalCutPro快捷键
FinalCutPro快捷键使用 FinalCutPro的快捷键使用十分有用,特对一些基本的快捷键进行了总结 1)i:截取片段开始Initial 2)o: 截取片段结束Over i和o可以在一个素材片 ...
- 黑马vue---14、v-model双向绑定
黑马vue---14.v-model双向绑定 一.总结 一句话总结: 1.v-bind 只能实现数据的单向绑定,从 M 自动绑定到 V, 无法实现数据的双向绑定 2.v-model 指令,可以实现 表 ...
- 转:extjs 添加loading状态的三种解决办法:
extjs 添加loading状态的三种解决办法: 方法一: //materialGrid 指需要显示loading状态的控件id var o=Ext.getCmp('materialGrid'); ...
- JPA 或者Hibernate 实体类说明
这里简单介绍Hibernate的Annotation注解 一.声明实体 @Entity对实体注释.任何Hibernate映射对象都要有这个注释@Table声明此对象映射到数据库的数据表,通过它可以为实 ...
- 提交SVN Working copy locked解决
今天一大早提交SVN的时候,出现这个错误: 百度了一下原因:因为我强制在commit的时候退出了,导致svn项目文件被锁了,不能commit,不能update了 赶紧百度了一下解决办法: http:/ ...
- 小程序onLaunch事件的坑
记一个小程序踩过的坑 小程序项目中app.js里面定义了globalData,即全局变量,里面定义了一个token字段 需求是这样的,每次进入小程序的时候需要检验该token有没有,没有就请求后台获取 ...
- Mybatis操作数据时出现:java.sql.SQLSyntaxErrorException: Unknown column 'XXX' in 'field list'
这个错误比较重要,而且很常见,故单独进行说明: Mybatis出现:Unknown column 'xxx' in 'field list' 先来看一下程序的内部: dao.addUser(" ...