-- 主键冲突(duplicate key)
insert into user(id,username,address) values(1,'xujian','anhui');
insert into user(id,username,address) values(2,'xiewei','anhui'); insert into user(id,username,address) values(2,'luyang','anhui');-- 主键冲突了
-- 可以选择性的进行处理,更新或替换
-- 主键冲突:更新操作
insert into user(id,username,address) values(2,'xiewei','liuan') on duplicate key update address='liuan';
-- 主键冲突:替换操作
replace into user(id,username,address) values(2,'luyang','hefei');
select * from user; -- 蠕虫复制:从已有的数据中去获取数据,然后将数据又进行新增操作,数据将成倍增加
-- 表创建高级操作:从已有表创建新表
create table copyuser like user; -- 只复制结构,不复制数据
-- 蠕虫复制:先查出数据,然后将查出的数据新增一遍
insert into copyuser select(id,username,address) from user;
-- 蠕虫复制的意义
-- 1、从已有表拷贝数据到新表中
-- 2、可以顺序让表中的数据膨胀到一定的数量级:测试表的压力以及效率 -- 更新数据
-- 基本语法:
update user set username='wanghui' where id=1; -- 删除:如果表中存在主键自增长,那么当删除之后,自增长不会还原
-- 数据的删除是不会改变表结构只能删除表后重建表
truncate 表名; -- 清空数据,但是保留表的结构 -- 高级查询
-- 去掉重复数据(所有字段都一样)
select distinct * from my_info;
-- 字段别名:当数据进行查询出来的时候,有时候名字并不一定就满足需求,
-- (多表查询的时候,会有同名字段),需要对字段名进行重命名
select name as 姓名,numbers as 学号 from my_info; select * from my_student,studentinfo;
-- 从一张表中取出一条记录,去另一张表中匹配所有的记录,而且全部保留:(记录数和字段数)
-- 将这种结果称为:笛卡尔积(交叉连接) -- 子查询:数据的来源是一条查询语句(查询语句的结果是二维表)
select * from (select * from my_student) as s; -- where子句:返回的结果:0或1,0代表false,1代表true
-- where是唯一一个直接从磁盘获取数据的时候就开始判断的条件:从磁盘取出一条记录,开始where判断,判断的结果如果成立保存到内存,如果失败直接放弃 -- group by 子句 :根据某个字段进行分组(相同的放一组,不同的分到不同的组)
-- 分组的意义:是为了统计数据(安祖统计:按组字段进行数据统计)
-- count:统计分组后的记录数(每一组有多少记录)
-- max:统计每组中最大的值
-- min:统计最小值
-- avg: 统计平均值
-- sum:统计和
select count(*),gender,avg(age) as 平均年龄,max(age) as 最大年龄,min(age) as 最小年龄,sum(age) as 年龄总和 from studentinfo group by gender; -- 分组会自动排序:根据字段默认排序
-- group by 字段[asc|desc]; 对分组的结果然后合并之后的整个结果进行排序 -- Having子句:与where子句一样,进行条件判断
-- where是针对磁盘数据进行判断,进入到内存之后,会进行分组操作,分组结果就需要having来做
-- Having能做where能做的几乎所有事情,但是where却不能做having能做的很多事情
-- 1.分组统计的结果或者说统计函数都只有having能够使用
-- 2.Having能够使用字段别名,where不能 -- order by排序:根据某个字段进行升序或者降序,依赖校对集
select * from studentinfo order by age asc; -- limit子句:是一种限制借结果的子句,限制数量
-- 有两种使用方式:
-- 方案一:只用来限制长度(数据量)
select * from studentinfo limit 2;
-- 方案二:限制起止位置,限制数量:limit 起始位置,限制数量
-- 主要用来实现数据的分页
select * from studentinfo limit 1,3;

mysql学习笔记(三)的更多相关文章

  1. MYSQL学习笔记三:日期和时间函数

    MYSQL学习笔记三:日期和时间函数 1. 获取当前日期的函数和获取当前时间的函数 /*获取当前日期的函数和获取当前时间的函数.将日期以'YYYY-MM-DD'或者'YYYYMMDD'格式返回 */ ...

  2. MySql学习笔记三

    MySql学习笔记三 4.DML(数据操作语言) 插入:insert 修改:update 删除:delete 4.1.插入语句 语法: insert into 表名 (列名1,列名2,...) val ...

  3. mysql学习笔记三 —— 数据恢复与备份

    要点: 1.存储引擎2.导入导出3.备份与恢复 查看当前数据库中的所有表use db1:show tables: 1.存储引擎 不同的发动机(引擎)适用的汽车类型不一样. 存储和处理的不同方式.不同的 ...

  4. MySQL学习笔记三:库和表的管理

    1.MySQL数据库服务配置好后,系统会有4个默认的数据库. information_schema:虚拟对象,其对象都保存在内存中 performance_schema:服务器性能指标库 mysql: ...

  5. mysql基本数据类型(mysql学习笔记三)

    Mysql数据类型 小数: 浮点:小数位可以变化 Float单精度默认精度6位左右 Double 双精度默认精度16位左右 支持,控制数值范围 Type(M,D) M表示所有数值位数(不包括小数点和符 ...

  6. MySQL学习笔记(三)—索引

    一.概述 1.基本概念       在大型数据库中,一张表中要容纳几万.几十万,甚至几百万的的数据,而当这些表与其他表连接后,所得到的新的数据数目更是要大大超出原来的表.当用户检索这么大量的数据时,经 ...

  7. MySQL学习笔记(三):常用函数

    一:字符串函数 需要注意的几个细节: 1.cancat中有一个字符串为null,则结果为null. 2.left(str,x) 和 right(str,x)中x为null,则不返回任何字符串,不是nu ...

  8. MySql学习笔记(三) —— 聚集函数的使用

    1.AVG() 求平均数 select avg(prod_price) as avg_price from products; --返回商品价格的平均值 ; --返回生产商id为1003的商品价格平均 ...

  9. Mysql学习笔记(三)对表数据的增删改查。

    正文内容. 这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mys ...

随机推荐

  1. mysql查询常用小语句

    mysql  查询某个库里表的数量 在mysql中有个数据库information_schema下的表tables记录了所有数据库中所有的表相关信息 TABLE_SCHEMA 数据库名称 SELECT ...

  2. IT 运营架构杂谈【前言】

    [ 什么是IT 服务 ?]   OGC官方的ITIL 服务定义: 中文定义:实施和管理 IT 服务,满足业务的需要.IT 服务管理由IT 服务提供方通过人员.流程和信息技术的适当组合而进行.   [ ...

  3. moodle中的完形填空题的文本编写方法

    moodle中的完形填空题的文本编写方法 [完形填空题]考题把一段文字挖去一些空,让考生根据上下文正确地完成这些填空.完型填空题中的一段短文可以包括各种题目,如选择,填空,和数字题等. 题目的编辑是在 ...

  4. C语言中的控制语句: 判断、环循等;

    列举这一部分的目的就是注意它的写法,尤其是 分号 : 的位置: 1. if-else if else 语句: if (表达式1) 语句1: else if (表达式2) 语句2: else 语句3: ...

  5. Unity导入3D模型的过程与方法

    一.介绍 资源是游戏开发中的原材料,也就是组成游戏的模块. Unity只是一个游戏开发引擎,而并不是一个资源开发软件.这就意味着在游戏中需要的资源通常是由一些设计者使用其他软件开发出来的,然后设计者会 ...

  6. 分享一个MAC下绕开百度网盘限速下载的方法,三步操作永久生效

    相信大家都比较困惑,百度网盘客户端限速后一般只有几十K的下载速度,Windows有百度网盘破解版,但MAC的破解版似乎不存在,要提速的话,一般的做法是开超级会员(27元/月),身为程序员的我们,是不是 ...

  7. Unity5-----------之GI设置简介

    GI global illumination 全局照明indirect illumination 间接照明模拟出光线追踪的效果 实现方法:1.ssao系列 2.lightmap.辐射度3.PBRT 实 ...

  8. Windows10锁屏壁纸提取

    CMD执行:  %localappdata%\Packages\Microsoft.Windows.ContentDeliveryManager_cw5n1h2txyewy\LocalState\As ...

  9. T4生成实体,单张表和多张表

    # 使用说明 . 把T4目录放在项目的根目录 . 配置连接字符串,在tt文件的最底部 . generateAllEntity.tt生成全部的实体类 . generateSingleEntityByNa ...

  10. java 项目 存入mysql后 变问号 MySql 5.6 (X64) 解压版 1067错误与编码问题的解决方案

    [参考]MySQL 5.7.19 忘记密码 重置密码 my.ini示例 服务启动后停止 环境 Java环境JDK1.8  安装好了 mysql-5.6.38-winx64  idea2016(64) ...