省份城市试题
#省份表
    -> select * from province;
+----+----------+
| id | province |
+----+----------+
|  1 | 广东     |
|  2 | 湖南     |
|  3 | 湖北     |
+----+----------+
3 rows in set

mysql> #城市表
    -> select * from city;
+----+------+------------+
| id | city | provinceid |
+----+------+------------+
|  1 | 广州 |          1 |
|  2 | 深圳 |          1 |
|  3 | 惠州 |          1 |
|  4 | 长沙 |          2 |
|  5 | 武汉 |          3 |
+----+------+------------+
#获得所有的城市并得出该城市的省
    -> select c.id,c.city,p.province from city c left join province p on c.provinceid=p.id;
+----+------+----------+
| id | city | province |
+----+------+----------+
|  1 | 广州 | 广东     |
|  2 | 深圳 | 广东     |
|  3 | 惠州 | 广东     |
|  4 | 长沙 | 湖南     |
|  5 | 武汉 | 湖北     |
+----+------+----------+
#获得所有省份,并查处该省份所有城市的个数
    -> select p.id,p.province,count(*) from city c left join province p on c.provinceid=p.id group by c.provinceid;
 
+----+----------+----------+
| id | province | count(*) |
+----+----------+----------+
|  1 | 广东     |        3 |
|  2 | 湖南     |        1 |
|  3 | 湖北     |        1 |
+----+----------+----------+

学生分数表

mysql> select * from score;
+----+----------+-------+-------+
| id | username | class | score |
+----+----------+-------+-------+
|  1 | 张三     | 语文  |    81 |
|  2 | 张三     | 数学  |    75 |
|  3 | 李四     | 语文  |    76 |
|  4 | 李四     | 数学  |    90 |
|  5 | 王五     | 语文  |    81 |
|  6 | 王五     | 数学  |   100 |
|  7 | 王五     | 英语  |    90 |
+----+----------+-------+-------+

获得学生的总分数,平均分数
    -> select id,username,sum(score),avg(score) from score group by username;
+----+----------+------------+------------+
| id | username | sum(score) | avg(score) |
+----+----------+------------+------------+
|  1 | 张三     | 156        | 78.0000    |
|  3 | 李四     | 166        | 83.0000    |
|  5 | 王五     | 271        | 90.3333    |
+----+----------+------------+------------+

#获得所有分数都大于80的学生的名字
select * from score group by username having min(score)>80;
+----+----------+-------+-------+
| id | username | class | score |
+----+----------+-------+-------+
|  5 | 王五     | 语文  |    81 |
+----+----------+-------+-------+

select distinct(username) from score where username not in (select username from score where score<80);
+----------+
| username |
+----------+
| 王五     |
+----------+

包含值
 select * from test;
+----+---------+
| id | data    |
+----+---------+
|  1 | 2       |
|  2 | 1,2     |
|  3 | 1,22,23 |
|  4 | 2,34    |
|  5 | 1,2,6   |
+----+---------+
5 rows in set
获得2的所有数据,但不要22等
mysql> select * from test where FIND_IN_SET(2,data);
+----+-------+
| id | data  |
+----+-------+
|  1 | 2     |
|  2 | 1,2   |
|  4 | 2,34  |
|  5 | 1,2,6 |
+----+-------+

常见的mysql数据库sql语句的编写和运行结果的更多相关文章

  1. MySQL 数据库SQL语句——高阶版本2

    MySQL 数据库SQL语句--高阶版本2 实验准备 数据库表配置: mysql -uroot -p show databases; create database train_ticket; use ...

  2. MySQL 数据库SQL语句——高阶版本1

    MySQL 数据库SQL语句--高阶版本 实验准备,数据表配置 mysql -uroot -p show databases; create database train_ticket; use tr ...

  3. MySQL数据库SQL语句基本操作

    一.用户管理: 创建用户: create user '用户名'@'IP地址' identified by '密码'; 删除用户: drop user '用户名'@'IP地址'; 修改用户: renam ...

  4. MySQL数据库sql语句的一些简单优化

    1.查询条件的先后顺序 有多个查询条件时,要把效率高能更精确筛选记录的条件放在后边.因为MySQL解析sql语句是从后往前的(不知是否准确). 例: select a.*,b.* from UsrIn ...

  5. MySQL 数据库--SQL语句优化

    explain查询和分析sql 开发中,为满足一业务功能,使用mysql书写sql时,一条sql往往有多种写法,那么我们就需要选择执行效率比较高的sql. 因此要比较分析sql的执行过程,且同一条sq ...

  6. mySQL数据库Sql语句执行效率检查--Explain命令

    mysql性能的检查和调优方法 Explain命令在解决数据库性能上是第一推荐使用命令,大部分的性能问题可以通过此命令来简单的解决,Explain可以用来查看SQL语句的执行效 果,可以帮助选择更好的 ...

  7. MYSQL数据库SQL语句集锦

    *特别说明:FILED代表数据表字段,CONDITIONS代表where之后的条件,TABLENAME代表数据表名   []中括号内的内容代表 可有可无. 创建数据库 create  database ...

  8. MySql数据库SQL语句将编码

    -- 查看所有字符编码 SHOW CHARACTER SET; -- 查看创建数据库的指令并查看数据库使用的编码 show create database dbtest; -- 查看数据库编码: sh ...

  9. MySQL数据库sql语句

    零.用户管理: 1.新建用户: >CREATE USER name IDENTIFIED BY 'ssapdrow'; 2.更改密码: >SET PASSWORD FOR name=PAS ...

随机推荐

  1. CF&&CC百套计划1 Codeforces Round #449 C. Willem, Chtholly and Seniorious (Old Driver Tree)

    http://codeforces.com/problemset/problem/896/C 题意: 对于一个随机序列,执行以下操作: 区间赋值 区间加 区间求第k小 区间求k次幂的和 对于随机序列, ...

  2. opencv 图像处理函数大全

    .cvLoadImage:将图像文件加载至内存: .cvNamedWindow:在屏幕上创建一个窗口: .cvShowImage:在一个已创建好的窗口中显示图像: .cvWaitKey:使程序暂停,等 ...

  3. SQL分页数据重复问题

    对于关系数据库来说,直接写SQL拉数据在列表中显示是很常用的做法.但如此便带来一个问题:当数据量大到一定程度时,系统内存迟早会耗光.另外,网络传输也是问题.如果有1000万条数据,用户想看最后一条,这 ...

  4. Understanding the Bias-Variance Tradeoff

    Understanding the Bias-Variance Tradeoff When we discuss prediction models, prediction errors can be ...

  5. 安装rqalpha的日志

    安装rqalpha的日志 用anaconda的控制台命令: pip install -i https://pypi.tuna.tsinghua.edu.cn/simple rqalpha rqalph ...

  6. 谈谈Flash图表中数据的采集

    一般来说flash中的数据是不能被现有技术很容易采集到的,但是也不能谈flash色变,要具体问题具体分析,有些flash是可以通过一些分析发现背后的数据.然后采集就变得很容易了. 具体案例:搜房房价走 ...

  7. Callable,Future,FutureTask

    1.概念定义 2.实现例子 3.总结   1.概念定义   1.Callable Callable是一个接口,效果类似Runnable接口.实现该接口,然后,耗时操作在call()方法中执行.与Run ...

  8. 关于new Handler()与new Handler(Looper.getMainLooper())区别

    如果你不带参数的实例化:Handler handler=new Handler();那么这个会默认用当前线程的Looper对象. 一般而言,如果你的Handler是要用来刷新UI的,那么就需要在主线程 ...

  9. 【算法学习】老算法,新姿势,STL——Heap

    “堆”是一个大家很熟悉的数据结构,它可以在\(O(log\;n)\)的时间内维护集合的极值. 这都是老套路了,具体的内部实现我也就不谈了. 我一般来说,都是用queue库中的priority_queu ...

  10. inspect的使用

    # -*- coding: utf-8 -*- # @Time : 2018/9/11 10:29 # @Author : cxa # @File : inspecttest.py # @Softwa ...