当前位置: 移动技术网 > IT编程>数据库>Mysql > mysql学习之基础篇04

mysql学习之基础篇04

2019年07月30日  | 移动技术网IT编程  | 我要评论
五种基本子句查询 查询是mysql中最重要的一环,我们今天就来说一下select的五种子句中的where条件查询: 首先我们先建立一张商品表:goods 由于商品数目太多,我就不一一列举了。 在这里我说一下这些列名都是什么意思: goods_id 主键;goods_name 商品名称;cat_id ...

五种基本子句查询

查询是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);

 

 

取出商品本店价格在100500之间的商品(含边界):

select * from goods where shop_price between 100 and 500;

 

 

取出商品栏目不在311的商品(andnot 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 '诺基亚%' ;

 

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

  • Ubuntu上Vim安装NERDTree插件的详细操作步骤

    Ubuntu上Vim安装NERDTree插件的详细操作步骤

    nerdtree是vim的文件系统浏览器,使用此插件,用户可以直观地浏览复杂的目录层次结构,快速打开文件以进行读取或编辑,以及执行基本的文件系统操作。nerdt... [阅读全文]
  • MySQL 4种常用的主从复制架构

    MySQL 4种常用的主从复制架构

    一主多从复制架构在主库读取请求压力非常大的场景下,可以通过配置一主多从复制架构实现读写分离,把大量的对实时性要求不是特别高的读请求通过负载均衡分部到多个从库上(... [阅读全文]
  • 浅析MySQL 备份与恢复

    1、简介数据无价,mysql作为一个数据库系统,其备份自然也是非常重要且有必要去做。备份的理由千千万,预防故障,安全需求,回滚,审计,删了又改的需求等等,备份的... [阅读全文]
  • 保障MySQL数据安全的一些建议

    数据是企业核心资产,数据对企业而言是最重要的工作之一。稍有不慎,极有可能发生数据无意泄露,甚至被黑客恶意窃取的风险。每年业界都会传出几起大事件,某知名或不知名的... [阅读全文]
  • MySQL如何快速修改表的表结构

    快速修改mysql某张表的表结构--摘录自《mysql管理之道》alter table 表名 modify 列名 数据类型; 这个命令可以修改表结构此外,也可以... [阅读全文]
  • MySQL 行锁和表锁的含义及区别详解

    一、前言对于行锁和表锁的含义区别,在面试中应该是高频出现的,我们应该对mysql中的锁有一个系统的认识,更详细的需要自行查阅资料,本篇为概括性的总结回答。mys... [阅读全文]
  • MySQL 如何查询当前最新事务ID

    写在前面:在个别时候可能需要查看当前最新的事务 id,以便做一些业务逻辑上的判断(例如利用事务 id 变化以及前后时差,统计每次事务的响应时长等用途)。通常地,... [阅读全文]
  • 如何优雅、安全的关闭MySQL进程

    前言本文分析了 mysqld 进程关闭的过程,以及如何安全、缓和地关闭 mysql 实例,对这个过程不甚清楚的同学可以参考下。关闭过程1、发起 shutdown... [阅读全文]
  • 详解MySQL8.0&#8203; 字典表增强

    详解MySQL8.0&#8203; 字典表增强

    mysql中数据字典是数据库重要的组成部分之一,information_schema首次引入于mysql 5.0,作为一种从正在运行的mysql服务器检索元数据... [阅读全文]
  • 简述MySQL InnoDB存储引擎

    前言:存储引擎是数据库的核心,对于 mysql 来说,存储引擎是以插件的形式运行的。虽然 mysql 支持种类繁多的存储引擎,但最常用的当属 innodb 了,... [阅读全文]
验证码:
移动技术网