mysql学习之基础篇04
五种基本子句查询
查询是mysql中最重要的一环,我们今天就来说一下select的五种子句中的where条件查询:
首先我们先建立一张商品表:goods
由于商品数目太多,我就不一一列举了。
在这里我说一下这些列名都是什么意思:
goods_id 主键;goods_name 商品名称;cat_id 商品所属栏目;goods_nummber 商品库存;shop_price 本店价格;market_pprice 市场价格;click_count 点击量。
我们取出主键为32的商品:
select * from goods where goods_id=32;select * from goods where goods_id=32;
我们注意,一定要把where表达式理解清楚,只要where后面的条件为真,那么语句就执行
我们看到主键为32的商品本店价格为3010,市场价格为3612,
那么我们也可以用
select * from goods where shop_price=3010 and market_price=3612;
来取出它
我们来取出商品栏目不等于3的商品:
select * from goods where cat_id !=3;
取出本店价格小于3000的商品:
select * from goods where shop_price<3000;
取出商品栏目是4和11的商品:
select * from goods where cat_id in (4,11);
取出商品本店价格在100到500之间的商品(含边界):
select * from goods where shop_price between 100 and 500;
取出商品栏目不在3和11的商品(用and和not in分别实现):
select * from goods where cat_id !=3 and cat_id !=11;
select * from goods where cat_id not in (3,11);
取出第三个栏目下面本店价格<1000或>3000,并且点击量>5的商品:
在这里我们使用括号来控制优先级:
select * from goods where cat_id=3 and (shop_price<1000 or shop_price>3000) and click_count>5;
模糊查询:like
%通配任意字符
_匹配单一字符
我们想查出名称以诺基亚为开头的商品:
select * from goods where goods_name like '诺基亚%';
我们想查出名称以诺基亚为开头,并且后面只有三个字符的商品:
select * from goods where goods_name like '诺基亚___';
把列当成变量,既然是变量,那就可以进行运算,比较
取出商品id,商品名,本店价格比市场价格省的钱:
select goods_id,goods_name,market_price - shop_price from goods ;
这种结果叫做广义投影。
我们还可以给列差价起个名字叫做discount,但是这个列并不在原表中存在,只存在于结果中:
select goods_id,goods_name,market_price-shop_price as discount from goods;
如果要对结果继续进行查询,需要用having:
比如我们想从上面的结果中取出差价大于200的商品:
select goods_id,goods_name,market_price-shop_price as discount from goods having discount>200;
一定注意这里的having不能换成where,否则会报错,因为我们是对结果进行再次查询,而不是从原来的表里面直接查询,因为原来的表里面没有discount这一列。
接下来我们用一道面试题来练习:
把下面表中[20,29]的值改为20,[30,39]的值改为30
这道题的核心在于我们要能想到把列当成一个变量来进行运算,对其除以10取模再乘10。
update mian set num=floor(num/10)*10 where num between 20 and 39;
再来做道练习题:把goods表中商品名为‘诺基亚xxxx’的商品名称显示为‘HTCxxxx’。
提示:用到两个函数,一个是截取字符串函数substring(),一个是连接字符串函数concat()。
select goods_name,concat('HTC',substring(goods_name,4)) from goods where goods_name like '诺基亚%' ;
mysql学习之基础篇04的更多相关文章
- mysql学习之基础篇01
大概在一周前看了燕十八老师讲解的mysql数据库视频,也跟着学了一周,我就想把我这一周所学的知识跟大家分享一下:因为是第一次写博客,所以可能会写的很烂,请大家多多包涵.文章中有不对的地方还请大家指出来 ...
- mysql学习之基础篇08 UTF8编码
这次我们来说一下在Mysql中的编码问题: 我们知道应用于计算机的最早的字符集是ASCII,它所组成的编码是ASCII编码:由于对于其他国家来说它所容纳的字符个数比较少,后来就出现了ANSI字符集,它 ...
- mysql学习之基础篇05
mysql中的统计函数: 1. 查询商品价格中最高的价格: select max(shop_price) from goods; 2. 查询商品价格中最低的价格: select min(shop_pr ...
- mysql学习之基础篇03
我们今天来进行建表的基本操作: 首先要建表就要了解列类型,因为建表就是声明列的过程,列声明完成了,表也就建好了. mysql中列分为三大类: 一.数值型 数值型又分为整型和浮点型两种. 先来看整型: ...
- MySQL学习之基础篇09-事务
我们在建表的时候通常会在最后声明引擎类型,这次我们就来看看存储引擎都有哪些: 举个例子: --------------------------- 银行转账: 张三想给李四转500元钱: 张三-500 ...
- mysql学习之基础篇07
视图:view 在查询的时候我们经常把查询到的结果当成一张临时表来看,其实view就可以看成一张虚拟表,是表通过某种运算得到的投影 那么如何创建视图?创建视图需要指定视图的列名和列类型吗? 答:不用, ...
- mysql学习之基础篇06
子查询:又分为where型子查询,from型子查询,exists型子查询这三类. where型子查询:指把内层查询的结果作为外层查询的比较条件: 举个例子: 我们想查出goods_id最大的商品,要求 ...
- mysql学习之基础篇02
我们来说一下表的增删改查的基本语法: 首先建立一个简单的薪资表: create table salary(id int primary key auto_increment,sname varchar ...
- iOS系列 基础篇 04 探究视图生命周期
iOS系列 基础篇 04 探究视图生命周期 视图是应用的一个重要的组成部份,功能的实现与其息息相关,而视图控制器控制着视图,其重要性在整个应用中不言而喻. 以视图的四种状态为基础,我们来系统了解一下视 ...
随机推荐
- Apache新的URL路由重写规则
在根目录下新建一个 .htaccess 后缀文件,将下面代码放进去即可 <IfModule mod_rewrite.c> Options +FollowSymlinks -Multivie ...
- jira中使用eazyBI
参考:https://docs.eazybi.com/eazybijira/set-up-and-administer/set-up-and-administer-for-jira-server/in ...
- LeetCode 566. 重塑矩阵(Reshape the Matrix)
566. 重塑矩阵 566. Reshape the Matrix 题目描述 LeetCode LeetCode LeetCode566. Reshape the Matrix简单 Java 实现 c ...
- 【LeetCode】四数之和【排序,固定k1,k2,二分寻找k3和k4】
给定一个包含 n 个整数的数组 nums 和一个目标值 target,判断 nums 中是否存在四个元素 a,b,c 和 d ,使得 a + b + c + d 的值与 target 相等?找出所有满 ...
- 装饰器login_required
装饰器login_required将游客身份引导至登录页面,登录成功后跳转到目的页面 url.py path('login/',views.login), path('home/',views.hom ...
- gitlab 安装、备份与还原及常见设置
gitlab 安装.备份与还原及常见设置 安装 安装过程比较简单,跑在 docker 上,执行命令即可 -v参数后面的值为卷的名称,自动创建数据卷(如果数据卷不存在) https://docs.git ...
- 解决Ubuntu 16.04 环境下Python 无法显示中文的问题
一.下载中文字体(https://pan.baidu.com/s/1EqabwENMxR2WJrHfKvyrIw 这里下载多是SImhei字体) 安装字体:解压:unzip SimHei.zip拷贝字 ...
- Crontab详细用法-定时任务详解
crontab是linux系统或unix系统中常用的定时命令,使用crontab你可以在指定的时间执行一个shell脚本或者一系列Linux/unix命令.例如系统管理员安排一个备份任务使其每天都运行 ...
- 编译基于obs-studio的阿里巴巴直播工具tblive的过程和常见问题解决
tblive 简介 tblive开源项目对应的产品是千牛主播,是一个独立的PC端主播工具,基于开源软件OBS Studio来修改定制. 项目说明 tblive是一款优秀的基于obs-studio的直播 ...
- .Net Core WebApi(1)— 入门
主要讲述利用EF Core的CodeFirst迁移数据库,简单接口增删改查的使用,利用Swagger生成接口文档. 1.新建项目 创建DbContext 和实体模型