Mysql 一些查询功能概念

1.最基本的通用查询:查询全表数据,SELECT * FROM 表名;实际开发中,写sql的时候,不能书写*

MySQL 条件查询 limit、in、between and、like等等

1、and (并且)

语法格式:

SELECT 字段1,字段2… FROM <表名> WHERE 字段名=值 and 字段名=值
SELECT * FROM test_user WHERE id=4 and username='终极it菜鸡';

2、or (满足其一)

语法格式:

SELECT 字段1,字段2… FROM <表名> WHERE 字段名=值 or 字段名=值
SELECT * FROM test_user WHERE id=2 or username='终极it菜鸡';

3、like (匹配查询)

语法格式

SELECT 字段1,字段2… FROM <表名> WHERE 字段名 LIKE 条件

这里牵扯到一个通配符 和LIKE 一起使用的有 ” %“ 和”__“;

  1. 百分号 (%) 可以匹配任意长度的字符。

    照常举个栗子 两边都放是前后都可以匹配任意长度的字符。 可以只在一边加

select * from test_user where username like ”%学%“;

下划线(__) 和 % 的用法相同 区别是% 可以匹配多个字符 而 (_ _ ) 只能匹配一个字符。 两边加是为了匹配两边 加一边加两边 根据实际需求来。

select * from test_user where username like ”_学_“;

4、limit (分页)

显示前N 行 简而言之 就是要查出几行数据。

SELECT * FROM <表名> LIMIT [位置偏移量] 行数
SELECT * FROM test_user  LIMIT 1,3;

通过这三条查询数据 应该能够看出位移偏移量是什么了吧,还有行数的意思应该也懂啦吧。

位移偏移量 就是 要从第几行开始查起 0 才表示 第一行数据

行数 : 就是从位移偏移量开始往后查 这个行数。

5、in (指定范围查询)

语法格式

SELECT 字段1,字段2… FROM <表名> WHERE 字段名 IN (值1,值2…)
SELECT * FROM test_user WHERE id IN (1,2,3);

6、between and (范围查询)

语法格式 这个是要查 这个范围的值 。

SELECT 字段1,字段2… FROM 表名 WHERE 字段名 BETWEEN 值1 AND 值2 ;

也可以 在前面加上 NOT 表示不查这个范围的值

SELECT 字段1,字段2… FROM 表名 WHERE 字段名 BETWEEN 值1 AND 值2 ;
SELECT * FROM test_user WHERE id  BETWEEN  1 AND 5 ;

7、is null (查询空值)

语法表 可以查询某字段内容为空的记录。

SELECT 字段名1,字段名2… FROM 表名 WHERE 字段名 IS NULL

 8.分组函数

求和:sum()、均值:avg()、最大值:max()、最小值:min()、求数目:count()、求日期差(天):datediff()

9.条件查询

select 
						     查询列表
						from 
						   表名
						 where 
								筛选条件

执行顺序 from 表名 where 筛选条件 select 查询列表

分类:

一:按条件表达式筛选

条件运算符:> < !=    <>(不等于的意思和!=同一个意思)  >= <=

     语法:
					select 
					     查询列表
					from 
					   表名
					 where 
							筛选条件
							
		执行顺序  from  表名   where  筛选条件  select 查询列表 				

二:按逻辑表达式筛选

		作用:用于连接条件表达式
		
			逻辑运算符: &&   ||    !   and   or   not
			
   &&和and:两个条件都为true,结果为true,反之为false
	
	||或or:    只要有一个为true,结果为true,反之为false
	
	!或not:如果连接的条件本身为false,结果为true,反之为false

三:模糊查询

	like
 
	 特点:
	 
 1:一般和通配符搭配使用
 
      通配符
      
				%  任意多个字符,包含0个字符
				
				_  任意单个字符,即一个字符
 between and  in
 
 is null |  is  not null

四:排序查询

语法:	

	select 	查询列表

		from 	表

	【where 	筛选条件】

order	by 	排序列表	【asc|desc】;

排序查询特点:

1:asc代表的是升序,desc代表的是降序 如果不写,默认是升序

2:order by子句可以支持 单个字段,别名,表达式,函数,多个字段

3:order by 子句在查询语句的最后面,除了limit子句。

10.条件表达式

WHERE表达式     

     条件表达式即是,对记录进行过滤,满足条件进行显示。如果没有指定WHERE子句,则显示所有记录;在WHERE表达式中,可以使用MySQL支持的函数或者运算符

root@localhost test>SELECT id,username FROM user WHERE id % 2 = 0;

2、GROUP...BY...

此外还可以进行分组,分组的时候即可以指定列名也可以指定列的位置,查询结果分组:

[GROUP BY {col_name | position } [ASC | DESC],...]

3、分组条件HAVING...

还可以带有分组条件HAVING

[HAVING where_condition]

现在来对sex进行分组,由于sex中只有两种“类型”,是0和NULL类型,因此会有两种分组

root@localhost test>SELECT sex FROM user GROUP BY sex;

11.Mysql中的统计函数(聚合函数)

  • max() 返回某列最大值
  • min() 返回某列最小值
  • count() 返回某列的行数
  • sum() 返回某列值和
  • avg() 返回某列的平均值

在使用count时,如果指定列名,则指定列的值为空的行被忽略,但如果COUNT函数中用的是星号(*),则不忽略。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL是一个流行的开源关系型数据库管理系统(RDBMS),它由瑞典公司MySQL AB开发,现在由MySQL AB的母公司甲骨文公司(Oracle Corporation)拥有。MySQL是一种流行的选择,因为它提供了高性能、可扩展性和可靠性,适用于各种规模的企业和开源项目。 以下是MySQL的一些关键概念和特点: 概念: 1. 关系型数据库:MySQL是一个关系型数据库管理系统(RDBMS),这意味着它以表格结构存储数据,并使用关系型数据库模型(如实体-关系图)来管理和查询数据。 2. 对象导向编程:MySQL使用对象导向编程模型,这意味着它支持数据库对象(如表、视图和索引)的创建、修改和删除。 3. 查询语言(SQL):MySQL使用结构化查询语言(SQL)进行数据操作和管理。SQL是用于操作关系型数据库的标准语言。 4. 跨平台兼容性:MySQL是一个跨平台数据库,可以在多种操作系统上运行,包括Windows、Linux、macOS等。 5. 社区支持:MySQL是一个广泛使用的开源数据库,拥有庞大的社区支持。这意味着用户可以获得来自全球各地的支持和帮助。 特点: 1. 高性能:MySQL具有出色的性能,能够处理大量数据和高并发请求。它使用InnoDB和MyISAM存储引擎,每个引擎都有其特定的性能优势。 2. 可扩展性:MySQL支持水平扩展,这意味着通过增加硬件资源,可以轻松地提高性能和容量。 3. 可靠性:MySQL具有高可用性和故障恢复功能,可以确保数据的安全性和一致性。它还支持复制和双机热备等高级功能。 4. 易用性:MySQL具有直观和简单的命令行界面和图形化管理工具,如phpMyAdmin和MySQL Workbench,这使得数据库管理和开发人员更容易使用。 5. 丰富的功能MySQL提供了丰富的功能,包括存储过程、触发器、视图和索引等,这些功能可以帮助开发人员更有效地组织和查询数据。 6. 兼容性:MySQL与许多编程语言和框架兼容,如PHP、Python、Java和Ruby等。这使得它成为许多应用程序的首选数据库系统。 总之,MySQL是一个功能强大、易于使用的关系型数据库管理系统,适用于各种规模的企业和开源项目。它具有高性能、可扩展性、可靠性、易用性和兼容性等特点,使其成为数据库管理的理想选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值