Database学习 - mysql 数据库 数据操作
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 数据库 数据操作的更多相关文章
- Database学习 - mysql 数据库 表操作
mysql 数据库 表操作 创建数据表 基本语法格式: 创建数据表: create table 表名( 字段名 datatype 约束, 字段名 datatype 约束, ...... ) 修改表名 ...
- Database学习 - mysql 数据库 事务操作
事务 事务指逻辑上的一组操作,组成这组操作的各个单元,要不全部成功,要不全部不成功. 数据库开启事务命令: start transaction 开启事务 rollback 回滚事务,即撤销指定的 ...
- Database学习 - mysql 连接数据库 库操作
连接数据库 语法格式: mysql -h 服务器IP -P 端口号 -u用户名 -p密码 --prompt 命令提示符 --delimiter 指定分隔符 示例: mysql -h 127.0.0.1 ...
- 第八章| 2. MySQL数据库|数据操作| 权限管理
1.数据操作 SQL(结构化查询语言),可以操作关系型数据库 通过sql可以创建.修改账号并控制账号权限: 通过sql可以创建.修改数据库.表: 通过sql可以增删改查数据: 可以通过SQL语句中 ...
- MySQL 数据库 -- 数据操作
数据的增删改 一 介绍 MySQL数据操作: DML ======================================================== 在MySQL管理软件中,可以通过 ...
- MySQL数据库----数据操作
注意的几点:1.如果你在cmd中书命令的时候,输入错了就用\c跳出 2.\s查看配置信息 一.操作文件夹(库) 增:create database db1 charset utf8; 删:drop d ...
- Database学习 - mysql 数据库 索引
索引 索引在mysql 中也叫 '键',是存储引擎用来快速找到记录的一种数据结构.索引对于良好的性能非常关键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要. 索引优化应该是对查询性能优化 ...
- Database学习 - mysql 数据库 多表/复合/子 查询
多表查询 多表查询,基本规则,通过两表有关联字段的进行条件匹配查询 内连接查询 方式一: SELECT 查看字段名[,查看字段名] FROM 一表名,二表名 WHERE 一/二表.字段 = 一/二表. ...
- Database学习 - mysql 数据库 外键
外键 外键约束子表的含义:如果在父表中赵达不到候选键,则不允许在子表上进行insert/update 外键预约对父表的含义:在父表上进行update/delete以更新或删除子表中有一条或多条对应匹配 ...
随机推荐
- 使用vscode 编写Markdown文件
markdown简单语法参考下面简单事例: # 一级标题 1. 有序列表1 >1. 有序列表1 >>- *test1* >>- **test2** >>- * ...
- BZOJ2124 等差子序列(树状数组+哈希)
容易想到一种暴力的做法:枚举中间的位置,设该位置权值为x,如果其两边存在权值关于x对称即合法. 问题是如何快速寻找这个东西是否存在.考虑仅将该位置左边出现的权值标1.那么若在值域上若关于x对称的两权值 ...
- 睡前小dp-codeforce414B-dp+一点点想法
http://codeforces.com/problemset/problem/414/B 定义一个串为好的串当这个串符合 di|di+1,1<i<k-1 给定一个n为串中元素的取值范围 ...
- BZOJ5337 [TJOI2018] 碱基序列 【哈希】【动态规划】
题目分析: 这道题的难点在于要取模,而题面没有写. 容易想到一个O(1E7)的dp.KMP或者哈希得到相关位置然后对于相关位置判断上一个位置有多少种情况. 代码: #include<bits/s ...
- Food HDU - 4292 (结点容量 拆点) Dinic
You, a part-time dining service worker in your college’s dining hall, are now confused with a new pr ...
- day5 算数,比较,赋值,逻辑运算符,表达式
算数运算符 + 加- 减* 乘/ 除// 整除% 取余** 指数 算数优先级: 指数>乘除>加减 ps:python里面区分优先级只有小括号 () 没有 [] 和 {} , 比较运算符 = ...
- Java“禁止”泛型数组
Java“禁止”泛型数组 原文:https://blog.csdn.net/yi_Afly/article/details/52058708 1. 泛型定义泛型编程是一种通过参数化的方式将数据处理与数 ...
- DP的各种优化(动态规划,决策单调性,斜率优化,带权二分,单调栈,单调队列)
前缀和优化 当DP过程中需要反复从一个求和式转移的话,可以先把它预处理一下.运算一般都要满足可减性. 比较naive就不展开了. 题目 [Todo]洛谷P2513 [HAOI2009]逆序对数列 [D ...
- 【UOJ#275】组合数问题(卢卡斯定理,动态规划)
[UOJ#275]组合数问题(卢卡斯定理,动态规划) 题面 UOJ 题解 数据范围很大,并且涉及的是求值,没法用矩阵乘法考虑. 发现\(k\)的限制是,\(k\)是一个质数,那么在大组合数模小质数的情 ...
- Android打造(ListView、GridView等)通用的下拉刷新、上拉自动加载的组件
原文 http://blog.csdn.net/bboyfeiyu/article/details/39253051 前言 下 拉刷新组件在开发中使用率是非常高的,基本上联网的APP都会采 ...