Mysql学习笔记(七)查(补充)

PS:五一还是要学习...虽然有点苦逼..但是路是自己选的,那么自己就要坚持的走下去...

学习内容:

1.数据库查找的补充...

查找涉及的东西比较多,在上一个章节没有完全介绍...我们还是以pet表格为例,在这里进行补充....

模式匹配:

  所谓模式匹配,无非就是按照某种模式进行查找...我们给出的一个模范,然后按照这个模范进行匹配完成的查找就属于模式匹配查找...模式匹配的查找中,我们不能够使用=或!=来操作,应该使用like或not like 进行操作...

//查找名字以b开头的宠物...
select * from pet where name like ‘b%‘;
//查找名字以fy结尾的宠物..
select * from pet where name like ‘%fy‘;
查找名字里包含w的宠物...
select * from pet where name like ‘%w%‘;

这类属于的是sql标准的模式匹配..还有另一种类型的匹配属于扩展正则表达式的模式匹配...下面进行简单介绍..

扩展正则表达式的一些字符..

  • ‘.‘匹配任何单个字符..
  • [...]匹配在方括号包括的字符,这个可以是指定值,也可以是一个范围值。。[abc]匹配字符只能有‘a‘,‘b‘,‘c‘为命名范围的字符..[a-z]匹配a-z之间为命名范围的字符..
  • ‘*‘匹配0个或者多个*之前的字符..

注意:

  • 如果regexp模式与被测值的任何地方匹配,那么该模式就匹配。。
  • 为了定位一个模式以便它必须匹配测试值的开头或者结尾...该模式开头使用‘^‘,或者结尾使用‘$‘。。
//查找所有以b开头的宠物名字...不区分大小写

select * from pet where name regexp ‘^b‘;

//区分大小写...

select * from pet where name regexp BINARY ‘^b‘;

//查找以fy结尾的宠物名字...

select * from pet where name regexp ‘fy$‘;

计数行:就是使用count(*)函数..

select count(*) from pet;//显示数据库数据的行数..

当我们想要查找一些特定的数据信息的时候..可以使用count(*)函数,配合着group by来进行查询..比如说,我们想要查询宠物猫和狗的数据信息的时候..我们没必要查询整个表,只需要使用count函数配合group by就可以查询的到..

select species,sex count(*) from pet where species="dog" or species="cat"group by species,sex;

常用的一些查询的例子:

比如说,我们建立了一个商店的数据库。。。商店里有一些物品,并且每件物品都有一个价值...

mysql>create table shop
->(
->       article int(4) unsigned zerofill default ‘0000‘ not null,
->       dealer char(20) default ‘‘ not null,
->       price double(16,2) default ‘0.00‘ not null,
->       primary key(article,dealer)
->);

mysql>insert into shop values(1,‘A‘,3.45),(1,‘B‘,3.99),(2,‘A‘,10.99),(3,‘B‘,1.45),(3,‘C‘,‘1.69‘),(3,‘D‘,1.25),(4,‘D‘,19.95);

1.查询列的最大值...
select max(article) as article from shop;

2.查询某个列的最大值的一行数据...两种方法..
select article,dealer,price from shop where price=(select max(article) from shop);
select article,dealer,price from shop order by price desc limit;

3.列的最大值,与第一个不一样的地方在于,第一个是显示所有物品里的最大值,这种属于显示每一种物品的一个最大值..
select article max(price) as price from shop order by article;

4.拥有某个字段的组间最大值的行..
select article,dealer,price from shop s1 where price=(select max(s2.price) from shop s2 where s1.article=s2.article);

第四条使用临时表的形式也可以做到...

CREATE TEMPORARY TABLE tmp
(
  article INT(4) UNSIGNED ZEROFILL DEFAULT ‘0000‘ NOT NULL,
  price  DOUBLE(16,2)       DEFAULT ‘0.00‘ NOT NULL
);
  
  LOCK TABLES article read;
  
  INSERT INTO tmp SELECT article, MAX(price) FROM shop GROUP BY article;
  
  SELECT article, dealer, price FROM shop, tmp
  WHERE shop.article=tmp.articel AND shop.price=tmp.price;
  
  UNLOCK TABLES;
  
  DROP TABLE tmp;

这个是看别人写的,自己并没有完全弄懂..有兴趣的可以研究研究...还有一种方式:

SELECT article,SUBSTRING( MAX( CONCAT(LPAD(price,6,‘0‘),dealer) ), 7) AS dealer, 0.00+LEFT(MAX( CONCAT(LPAD(price,6,‘0‘),dealer) ), 6) AS price FROM shop
GROUP BY article;

使用用户变量:

如果我们想要找出价格最高和最低的物品..并且还不想保存到客户端的临时变量中时..我们可以使用用户变量...

mysql> SELECT @min_price:=MIN(price),@max_price:=MAX(price) FROM shop;
mysql> SELECT * FROM shop WHERE price=@min_price OR price=@max_price;

查询还有使用外键查询。。使用auto_increment查询...自己只是了解,就不在这里班门弄斧了...

时间: 2025-01-05 06:34:47

Mysql学习笔记(七)查(补充)的相关文章

MySQL学习笔记七:存储引擎

1.MySQL存储引擎的设计采用“插件式”方案,用户可以很方便地选择使用哪种存储引擎,想使用mysql没有提供的引擎时,可以自己安装进去. 查看支持的存储引擎 mysql> show engines\G *************************** 1. row *************************** Engine: FEDERATED Support: NO Comment: Federated MySQL storage engine Transactions: N

mysql查询语句(mysql学习笔记七)

Sql语句 一般顺序GHOL : group by,having ,order by,limit     如果是分组,应该使用对分组字段进行排序的group by语法                     Limit start ,length                    去除重复记录默认为all Select distinct 字段  from Select distinct * from 没用(所有字段组合不相同才认为不相同,用在这里基本没用),记录值完全一样时取其一个 Unio

Mysql学习笔记(三)对表数据的增删改查。

写在前面:(一些牢骚,可以直接跳到分割线后) 太过敏感的人不会快乐,不幸的是我正是这种性格的人. 从培训机构毕业后,迫于经济方面的压力,和当时的班里的一个同学住在了一起,我们在一个公司上班.谁知道这都是不开心生活的源头,从每天早晨开始心情就很糟糕.他是个脾气很慢的人,我是个急脾气,特别是在早上上班的时候.由此种种吧,实在是不胜枚举.算了,还是不说了,太痛苦了,我不太喜欢说别人的坏话.我是学心理学的,已经用各种方法去安慰自己,但是都不太奏效. 回想以往和朋友的交往中,我虽然不算十分合群的人,但绝对

Mysql学习笔记(六)增删改查

原文:Mysql学习笔记(六)增删改查 PS:数据库最基本的操作就是增删改查了... 学习内容: 数据库的增删改查 1.增...其实就是向数据库中插入数据.. 插入语句 insert into table_name values("要插入的数据"); 比如说,我们先创建一个宠物表,用来记录宠物的基本信息以及所有者... create table pet ( name varchar(20), owner varchar(20), species varchar(20), sex cha

马哥学习笔记七——LAMP编译安装之MYSQL

1.准备数据存放的文件系统 新建一个逻辑卷,并将其挂载至特定目录即可.这里不再给出过程. 这里假设其逻辑卷的挂载目录为/mydata,而后需要创建/mydata/data目录做为mysql数据的存放目录. 2.新建用户以安全方式运行进程: # groupadd -r mysql # useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql # chown -R mysql:mysql /mydata/data 3.安装并初始化my

Mysql学习笔记(二)数据类型 补充

原文:Mysql学习笔记(二)数据类型 补充 PS:简单的补充一下数据类型里的String类型以及列类型... 学习内容: 1.String类型 2.列类型存储需求 String类型: i.char与varchar char与varchar的类型相似,但是他们的保存方式和检索方式不同... char的存储结构是固定长度的存储...即指定了几个字节,那么就占用几个字节,如char(4),那么无论存入的是什么字串,那么都占用四个字节...char的 可表示长度范围为0-255的任何值,当保存的字节不

MySql学习笔记(转载)

/* 启动MySQL */net start mysql /* 连接与断开服务器 */mysql -h 地址 -P 端口 -u 用户名 -p 密码 /* 跳过权限验证登录MySQL */mysqld --skip-grant-tables-- 修改root密码密码加密函数password()update mysql.user set password=password('root'); SHOW PROCESSLIST -- 显示哪些线程正在运行SHOW VARIABLES -- /* 数据库操

MySQL学习笔记—触发程序

MySQL学习笔记-触发程序 触发程序是与表有关的命名数据库对象,当表上发生特定事件时,将触发执行相应的触发程序. CREATE TRIGGER语法 CREATE TRIGGER语法: CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name FOR EACH ROW trigger_stmt 触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象. 触发程序与命名为tbl_name的表相关.tbl_na

CCNA学习笔记七——路由概述

静态路由协议: 动态路由协议:AS(自治系统):执行统一路由策略的一组设备的集合 EGP(外部网关协议): BGP:边界网关协议 IGP(内部网关协议): 距离矢量协议: RIP:V1,V2 IGRP EIGRP 链路状态路由协议: OSPF IS-IS 静态路由: 特点: 路由表是手工设置的 除非网络管理员干预,否则静态路由不会发生变化 路由表的形成不需要占用网络资源 适合环境 一般用于网络规模很小,拓扑结构固定的网络中 默认路由: 特点: 在所有路由类型中,默认路由优先级最低 适用环境: 一

mysql学习笔记--第1天

1.像网页上的账户.图片.文章都是存在数据库里面2.Oracle .DB2 .SQL server等等多钟数据库 PHP中选择使用mysql PHP+mysql黄金搭档 PHP和mysql都是开源的,免费实用,配置性好. mysql中小型适合,但没有Oracle强大.3.mysql的架构:C/S client/server 在server端开启,client端操作 mysql DBMS(DB代表数据库 M代表管理 S代表系统)客户端操作 服务器端---数据库--数据表--(行(记录),行(字段)