mysql的插入数据和查询

原创 2016年06月01日 20:45:24

mysql第二篇

数据操作语言(DML,Data Manipulation Language)

数据插入(添加数据)

  • 形式一

insert into 表名(字段名1,字段名2,....)values (值a1,值a2, .....), (值b1,值b2, .....),..... ;

  • 形式二

insert into 表名1(字段名1,字段名2,....)select 字段名1,字段名2,.... from 表名2;

  • 形式三

insert into 表名 set 字段名1=值1,字段名2=值2, ..... ;

  • 载入外部“形式整齐”(表格形式)的数据:

load data infile ‘文件完整名(含路径)’ into table 表名;

  • 制一个表的结构和数据:

create table 表名1 select * from 表名2;

删除数据

  • delete from 表名 [where条件] [order排序] [limit限定];

类似删除语句truncate:

  • truncate [table] 表名;用于直接删除整个表(结构)并重新创建该表。

可删除表是先将表摧毁然后重建表结构 删除数据量大的表时较快;

修改数据

  • update 表名 set 字段名1=值表达式1,字段名2=值表达式2,....[where条件] [order排序] [limit限定];

UPDATE student SET gender='男',age=30 WHERE id=2;

数据查询语言(DQL,Data Query Language)

查询语句

  • select [all | distinct] 字段或表达式列表 [from子句] [where子句] [group by子句] [having子句] [order by子句] [limit子句];
  • [all | distinct]

用于设定所select出来的数据是否允许出现重复行(完全相同的数据行)

all:允许出现——默认不写就是All(允许的)。

distinct:不允许出现——就是所谓的“消除重复行”。

  • 查询所有列
SELECT * FROM student;
  • 查询指定列
SELECT id,NAME,gender FROM student;
  • 查询时添加常量列
# 需求: 在查询student表时添加一个班级列,内容为“java就业班”
SELECT id,NAME,gender,age,'java就业班' AS '年级'  FROM student;
  • 查询时合并列
-- 需求: 查询每个学生的servlet和jsp的总成绩
SELECT id,NAME,(servlet+jsp) AS '总成绩' FROM student;
-- 注意:合并列只能合并数值类型的字段
SELECT id,(NAME+servlet) FROM student;
  • 查询时去除重复记录
-- 需求: 查询学生的性别     男 女
SELECT DISTINCT gender FROM student;
-- 另一种语法
SELECT DISTINCT(gender) FROM student;
-- 需求: 查询学生所在的地区
SELECT DISTINCT address FROM student;
  • 条件查询
--  条件查询(where)
--  逻辑条件: and(与)     or(或)
-- 需求: 查询id为2,且姓名为李四的学生
SELECT * FROM student WHERE id=2 AND NAME='李四'; -- 交集

-- 需求: 查询id为2,或姓名为张三的学生
SELECT * FROM student WHERE id=2 OR NAME='张三'; -- 并集

-- 比较条件: >   <   >=  <=  =  <>(不等于)     between and (等价于>= 且 <=)
-- 需求: 查询servlet成绩大于70分的学生
SELECT * FROM student WHERE servlet>70;

-- 需求: 查询jsp成绩大于等于75,且小于等于90分的学生
SELECT * FROM student WHERE jsp>=75 AND jsp<=90;
-- 另一个语法
SELECT * FROM student WHERE jsp BETWEEN 75 AND 90; -- (包前包后)

SELECT * FROM student WHERE gender<>'男';


--  判空条件(null 空字符串):  is null / is not null / =''  / <>''
-- 需求: 查询地址为空的学生(包括null和空字符串)
-- null vs  空字符串
-- null:表示没有值
-- 空字符串:有值的!
-- 判断null
SELECT * FROM student WHERE address IS NULL ;
-- 判断空字符串
SELECT * FROM student WHERE address='';

SELECT * FROM student WHERE address IS NULL OR address=''; -- (包括null和空字符串)

-- 需求: 查询有地址的学生(不包括null和空字符串)
SELECT * FROM student WHERE address IS NOT NULL AND address<>'';

-- 模糊条件: like
-- 通常使用以下替换标记:
-- % : 表示任意个字符
-- _ : 表示一个字符
-- 需求: 查询姓‘张’的学生
SELECT * FROM student WHERE NAME LIKE '李%';

-- 需求: 查询姓‘李’,且姓名只有两个字的学生
SELECT * FROM student WHERE NAME LIKE '李_';
  • 聚合查询
-- 聚合查询(使用聚合函数的查询)
 -- 常用的聚合函数: sum()  avg()  max()  min()  count()
-- 需求:查询学生的servlet的总成绩 (sum() :求和函数)
SELECT SUM(servlet) AS 'servlet的总成绩' FROM student;

-- 需求: 查询学生的servlet的平均分
SELECT AVG(servlet) AS 'servlet的平均分' FROM student;

-- 需求: 查询当前servlet最高分
SELECT MAX(servlet) AS '最高分' FROM student;

-- 需求: 查询最低分
SELECT MIN(servlet) AS '最低分' FROM student;

-- 需求: 统计当前有多少学生(count(字段))
SELECT COUNT(*) FROM student;

SELECT COUNT(id) FROM student;

-- 注意:count()函数统计的数量不包含null的数据
-- 使用count统计表的记录数,要使用不包含null值的字段
SELECT COUNT(age) FROM student;
  • 分页查询
-- 分页查询(limit 起始行,查询几行)
-- 起始行从0开始
-- 分页:当前页  每页显示多少条
-- 分页查询当前页的数据的sql: SELECT * FROM student LIMIT (当前页-1)*每页显示多少条,每页显示多少条;

-- 需求: 查询第1,2条记录(第1页的数据)
SELECT * FROM student LIMIT 0,2;
-- 查询第3,4条记录(第2页的数据)
SELECT * FROM student LIMIT 2,2;
-- 查询第5,6条记录(第3页的数据)
SELECT * FROM student LIMIT 4,2;
-- 查询第7,8条记录 (没有记录不显示)
SELECT * FROM student LIMIT 6,2;
  • 查询排序
--  查询排序(order by )
-- 语法 :order by 字段 asc/desc
-- asc: 顺序,正序。数值:递增,字母:自然顺序(a-z)
-- desc: 倒序,反序。数值:递减,字母:自然反序(z-a)

-- 默认情况下,按照插入记录顺序排序
SELECT * FROM student;

-- 需求: 按照id顺序排序
SELECT * FROM student ORDER BY id ASC;
SELECT * FROM student ORDER BY id; -- 默认正序

SELECT * FROM student ORDER BY id DESC;-- 反序

-- 注意:多个排序条件
-- 需求: 按照servlet正序,按照jsp的倒序
SELECT * FROM student ORDER BY servlet ASC,jsp DESC;
  • 分组查询
-- 分组查询(group by)
-- 需求: 查询男女的人数
-- 预期结果:
  --  男   3
  --- 女   2
  -- 1) 把学生按照性别分组(GROUP BY gender)
  -- 2) 统计每组的人数(COUNT(*))
SELECT gender,COUNT(*) FROM student GROUP BY gender;
  • 分组查询后筛选
- 分组查询后筛选
-- 需求: 查询总人数大于2的性别
-- 1) 查询男女的人数
-- 2)筛选出人数大于2的记录(having)
--- 注意: 分组之前条件使用where关键字,分组之前条件使用having关键字
SELECT gender,COUNT(*) FROM student WHERE GROUP BY gender HAVING COUNT(*)>2;
版权声明:本文为博主原创文章,未经博主允许不得转载。

MySQL将查询结果插入到数据表中

MySQL将查询结果插入到数据表中  转载自:http://www.baike369.com/content/?id=5582 INSERT语句还可以将SELECT语句...
  • youluo001
  • youluo001
  • 2016年08月19日 19:48
  • 17420

MySQL获取刚插入的数据

获取插入数据库的数据,截取Evidence时,很必要。
  • f1520107395
  • f1520107395
  • 2014年11月01日 00:05
  • 2682

Mysql 千万级数据量插入和查询应该怎么优化

关于插入: 宏观上:建二个表,其中一个表不建主键,不键索引。只记录,到了晚上,在把这个表的记录导入 有主键有索引的表里。方法的目的,二表,一表为插入最优化,另一表为查询最优化。 微观上:以下是涉及...
  • evan_endian
  • evan_endian
  • 2013年03月08日 19:31
  • 10587

MySQL 从外表查询(并截取固定长度)批量插入数据到表中

MySQL 从外表查询(并截取固定长度)批量插入数据到表中譬如 我有张用户表 user 这是用户表中的数据 我有张任务表 这是任务表中的数据 现在我有第三张表 叫做任务分配表...
  • theglobal
  • theglobal
  • 2017年04月25日 10:43
  • 544

mysql blob数据的插入与查询

举例将一个本地图片读入到mysql里面的表字段  msg_body,这个字段为blob类型,并将该数据查询并写入到一个图片 代码如下:连接mysql省略,只列重点: 插入数据到表里面,   ...
  • wushuang443
  • wushuang443
  • 2017年06月02日 10:09
  • 1013

MySQL——索引的使用对查询、插入速度的影响

MySQL——索引的使用对查询、插入速度的影响 一.什么是索引? 1.索引; 2.索引的作用; 3.索引的几个特点; 4.索引的算法。 二.验证索引对查询、插入速度的影响; ·实验工具 ·实验步骤 三...
  • G_Codes
  • G_Codes
  • 2017年11月05日 23:36
  • 150

MySQL将查询结果插入到数据表中

MySQL将查询结果插入到数据表中  转载自:http://www.baike369.com/content/?id=5582 INSERT语句还可以将SELECT语句...
  • youluo001
  • youluo001
  • 2016年08月19日 19:48
  • 17420

MySQL 插入数据

插入数据使用 INSERT 插入完整的行插入行的一部分插入多行插入某些查询的结果 插入完整的行 先看一下原有的customer列表: 插入一行: INSERT INTO customers...
  • liuying_1001
  • liuying_1001
  • 2014年07月28日 22:28
  • 11673

mysql 数据量大时插入和查询性能

现在mysql中有数据33.8w的数据,然后做查询和更新或插入操作,速度很慢,基本100条数据就要1.68s。好慢啊,我要测试一下,到底慢在哪?能不能提高点速度? 参考一篇博文:http://blog...
  • familyshizhouna
  • familyshizhouna
  • 2015年06月26日 13:29
  • 2766

mysql中插入中文数据

今天遇到的问题使mysql中插入中文数据后显示乱码,我在mysql中插入中文的时候,可以插入可是select的时候却无法显示,为此我写下这篇博客用于解决mysql插入中文。     由于有些截图没有...
  • zr1076311296
  • zr1076311296
  • 2016年06月21日 13:46
  • 3961
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:mysql的插入数据和查询
举报原因:
原因补充:

(最多只允许输入30个字)