mysql数据操作


查询语法

select * | field1,field1 ... from 表名
where 条件
group by 字段
having 筛选
order by 字段
limit 显示条数

  

  条件查询记录

     select * from 表名;
select 字段名 from 表名; select distinct 字段名 from 表名;
//distinct 可以去重字段数据
//salary 非空字段 select 字段 as 别名 [,字段 as 别名] from 表名;
//别名应用,只显示,并不影响存储数据. select 字段名 from 表名 where 条件;
// where 语句中可以使用的:
运算符 : > , < , = , <=,>=, !=,<>
区间: 字段 between 10 and 100 //值在 10 到100 之间的
包含关系: 字段 in (10,20,30) //值是10或20或30
匹配数据: 字段 like 'he %' // %表示任意多字符, _表示一个字符.
逻辑运算: and , or ,is
正则表达式: regexp "正则表达式" //having 语句中可以使用的:(跟where 区别是group by 后不能用where)
运算符 : > , < , = , <=,>=, !=,<>
区间: 字段 between 10 and 100 //值在 10 到100 之间的
包含关系: 字段 in (10,20,30) //值是10或20或30
匹配数据: 字段 like 'he %' // %表示任意多字符, _表示一个字符.
逻辑运算: and , or ,is
正则表达式: regexp "正则表达式"

  where 跟 having 区别:

1.where 语句只能在分组之前筛选,having可以用在分组之后的筛选;

2.使用where语句的地方都可以用having进行替换

3.having中可以用聚合函数,where中不能

  order by 排序(默认升序)

 select 字段名 from 表名 where 条件 order by 字段;       (升序)
select 字段名 from 表名 where 条件 order by 字段 desc; (降序)

  group by 分组查询

group by 分组查询:
注意,按分组条件分组后每一组只会显示第一条记录
其后可以接多个列名,也可以跟having字句,对group by 的结果进行筛选. select * from 表名 group by 字段名 select * from 表名 group by 2 //表示以表第二个字段分组查询

  limit 查询

select * from 表名 limit 2;   //显示前两条
select * from 表名 limit 2 , 2 ; //跳过2条显示2条

  exists 关键字

select * from 表名  where exists 条件
在where exists 返回是一个 true/false ,true则执行select * from 表名,false 返回为空.

  聚合函数:

常用的组函数

①每个组函数接收一个参数

②默认情况下,组函数忽略列值为null的行,不参与计算

③有时,会使用关键字distinct剔除字段值重复的条数

  注意:

  1)当使用组函数的select语句中没有group by子句时,中间结果集中的所有行自动形成一组,然后计算组函数;

  2)组函数不允许嵌套,例如:count(max(…));

  3)组函数的参数可以是列或是函数表达式;

  4)一个SELECT子句中可出现多个聚集函数.

查询过程中 各语句的执行顺序:

  重点:

  select , from , where , group by , having , order by 执行顺序.

mysql 在执行sql语句时的执行顺序:

 from  > where  > select > group by > having > order by


插入数据

# set方式插入
insert into 表名 set 字段 = 数值; # 一次性插入多个
insert into 表名 (字段1, 字段2) values('数值1', '数值2'),('数值1', '数值2'); # 插入时有主键冲突,改为更新字段操作
insert into 表名 (字段1, 字段2) values('数值1', '数值2') on duplicate key update '字段2 = '数值2'; #冲突替换,否则插入
replace into 表名(字段1, 字段2) values('数值1', '数值2');

修改数据

update 表名 set 字段名 = 新数值[,字段名 = 新数值]  where 筛选修改字段 = 筛选数值;

删除数据

delete from 表名 where 筛选删除字段 = 筛选数值[or/and  筛选删除字段 = 筛选数值];

删除表

delete table 表名 ;
truncate 表名; //这种操作会删除表后重新建同名表,字段多时

Database学习 - mysql 数据库 数据操作的更多相关文章

  1. Database学习 - mysql 数据库 表操作

    mysql 数据库 表操作 创建数据表 基本语法格式: 创建数据表: create table 表名( 字段名 datatype 约束, 字段名 datatype 约束, ...... ) 修改表名 ...

  2. Database学习 - mysql 数据库 事务操作

    事务 事务指逻辑上的一组操作,组成这组操作的各个单元,要不全部成功,要不全部不成功. 数据库开启事务命令: start transaction   开启事务 rollback  回滚事务,即撤销指定的 ...

  3. Database学习 - mysql 连接数据库 库操作

    连接数据库 语法格式: mysql -h 服务器IP -P 端口号 -u用户名 -p密码 --prompt 命令提示符 --delimiter 指定分隔符 示例: mysql -h 127.0.0.1 ...

  4. 第八章| 2. MySQL数据库|数据操作| 权限管理

    1.数据操作 SQL(结构化查询语言),可以操作关系型数据库 通过sql可以创建.修改账号并控制账号权限:  通过sql可以创建.修改数据库.表:  通过sql可以增删改查数据: 可以通过SQL语句中 ...

  5. MySQL 数据库 -- 数据操作

    数据的增删改 一 介绍 MySQL数据操作: DML ======================================================== 在MySQL管理软件中,可以通过 ...

  6. MySQL数据库----数据操作

    注意的几点:1.如果你在cmd中书命令的时候,输入错了就用\c跳出 2.\s查看配置信息 一.操作文件夹(库) 增:create database db1 charset utf8; 删:drop d ...

  7. Database学习 - mysql 数据库 索引

    索引 索引在mysql 中也叫 '键',是存储引擎用来快速找到记录的一种数据结构.索引对于良好的性能非常关键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要. 索引优化应该是对查询性能优化 ...

  8. Database学习 - mysql 数据库 多表/复合/子 查询

    多表查询 多表查询,基本规则,通过两表有关联字段的进行条件匹配查询 内连接查询 方式一: SELECT 查看字段名[,查看字段名] FROM 一表名,二表名 WHERE 一/二表.字段 = 一/二表. ...

  9. Database学习 - mysql 数据库 外键

    外键 外键约束子表的含义:如果在父表中赵达不到候选键,则不允许在子表上进行insert/update 外键预约对父表的含义:在父表上进行update/delete以更新或删除子表中有一条或多条对应匹配 ...

随机推荐

  1. day30 __hash__ 计算哈希值

    hash() # __hash__哈希的时候会根据内存地址进行哈希,因为地址不同所以哈希的值也不同,哪怕是完全一样子的属性得出的哈希值也不一样因此存在需要某些时刻期望属性相同得出相同哈希值可以控制对象 ...

  2. Leetcode 191.位1的个数 By Python

    编写一个函数,输入是一个无符号整数,返回其二进制表达式中数字位数为 '1' 的个数(也被称为汉明重量). 示例 : 输入: 11 输出: 3 解释: 整数 11 的二进制表示为 00000000000 ...

  3. Leetcode 242.有效的字母异位词 By Python

    给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的一个字母异位词. 示例 1: 输入: s = "anagram", t = "nagaram" ...

  4. 自学Zabbix7.1 IT services

    自学Zabbix7.1 IT services 1. 概念IT Services 服务器或者某项服务.业务的可用率,不懂技术的上级领导会过问最近服务器可用率如何.所有api的状况怎么样?通常一些技术人 ...

  5. Java NIO -- DatagramChannel

    Java NIO中的DatagramChannel是一个能收发UDP包的通道.操作步骤:打开 DatagramChannel接收/发送数据 代码举例: package com.soyoungboy.n ...

  6. android关闭日志

    我们在开发时,经常会输出各种日志来debug代码.但是等到应用发布的apk运行时不希望它输出日志. 关闭输出日志Log.v(),Log.i(),Log.w(),Log.v(),Log.e()等 原理: ...

  7. dij与prim算法

    两种算法本质是相同的. 都是从某一个点开始进行延伸,不断更新一个dis值,直到所有的点都被遍历到,从而求出一个最短路或者是一个树的边权的最小总和. 朴素算法都是n^2,都可以采用堆优化处理,降低复杂度 ...

  8. [luoguU42591][小T的面试题]

    luoguU42591 题意: n个不超过n的正整数中,其中有一个数出现了两次,其余的数都只出现了一次, 求这个出现两次的数. 思路: 这个题的亮点在于内存限制1MB.明显不能再用数组储存了,肯定是用 ...

  9. (转)使用 Spring缓存抽象 支持 EhCache 和 Redis 混合部署

    背景:最近项目组在开发本地缓存,其中用到了redis和ehcache,但是在使用注解过程中发现两者会出现冲突,这里给出解决两者冲突的具体方案. spring-ehcache.xml配置: <?x ...

  10. Windows下安装Python扩展模块提示“Unable to find vcvarsall.bat”的问题

    本文内容 Unable to find vcvarsall.bat的问题描述 问题分析 总结 提示: 如果你只是想知道自己需要安装哪个版本的Visual Studio请直接查看本文最后一个小节的内容. ...