数据库基础之高级查询(数据库查询)

数据库基础之高级查询(数据库查询)

普通查询

Select 列1[,列2,……] from 表名; 取出对应列所有行的数据;

要项取出对应列几行数据那么要加条件;

select sName,sAge from Student where sAge=18

 

排序

默认情况下查询会按照表中主键升序来显示数据;可以改变

SELECT sid,sName,sAge FROM Student order by sid desc[asc]

默认为升序

多个列之间以逗号分割,优先级依次降低

SELECT sid,sName,sAge FROM Student order by sName,sAge desc

需要条件排序放在条件之后

SELECT sid,sName,sAge FROM Student where sAge>=18 order by sName,sAge desc

 

limit(限制)关键字

limit后面有2个整数关键字,类似于字符串截取,第一个开始记录的索引,第二个代表取的长度

Select * from Student limit 1,1

从第2条记录开始取1条记录

limit关键字优先级:条件>排序>limit

SELECT * FROM `student` where sAge>=18 order by sid desc limit 0,3

 

关键字搜索

查询姓名中包含“张三”所有记录行,

%代表任意个任意的字符,可以是没有

SELECT * FROM `student` WHERE sName like '%张三%'

_代表任意一个字符,不能是没有

SELECT * FROM `student` WHERE sName like '张_'

 

聚合查询

获取数值列的最大max、最小min、平均avg、求和sum、是否重复distinct、统计行数count等查询

Select max(sage),min(sage),avg(sage),sum(sage),distinct(sname),count(sid) from student;

TIPS:聚合查询不得和普通列一起使用,原因是聚合查询一般只有一个值,而普通可能有很多值,非要使用可以分组,普通列必须要放在group by 后!!!

select sname,max(sage) from student 该行错误。

 

分组查询

select sname,max(sage) from student group by sname

 

链接查询

内联

select student.*,sccode from student,studentcode where student.scid=studentcode.scid; (推荐

以上的语法标准的写法

select student.*,sccode from student

inner join

studentcode on student.scid=studentcode.scid

 

左外联

select student.*,sccode from studentcode

left join

student on

student.scid=studentcode.scid

 

右外联

SELECT student . * , sccode

FROM studentcode

RIGHT JOIN student ON student.scid = studentcode.scid

 

子查询

在原来查询的基础继续查询,一般情况下用小括号包含。例如作为临时表

select sid,sname as 姓名,sage,sccode from

(select student.*,studentcode.sccode from student,studentcode where

student.scid=studentcode.scid) as tempTable

还有用子查询作为条件(查询出来的结果只能有一列)

只有一个值

select * from student

where sage=

(select max(sage) from student)

如果有多个值,条件应用in,代表范围

select * from student where sage in

(select sage from student)

还可以有明确条件的写法

select * from student where sage in(19,18)

 

特例

连接查询

Select a+b from table1 –将表table1中查询的a列b列合并输出,也可以2张表合并一列输出

Select a from table1 uinon select b from table2

交叉查询

在链表查询的过程中,有2点需要注意

  • 有重复的列一定要指明属于哪张表
  • 链表条件不对,那么查询出来的数据就是 主键数据条数*外键表数据条件

 

完整的建库建表语句如下

drop database if exists Test;

create database Test default character set utf8 collate

 

utf8_bin;

use Test;

create table StudentCode(

scID int primary key auto_increment,

scCode varchar(18) not null,

unique(scCode)

);

 

create table Student(

sid int primary key auto_increment,

sName varchar(16),

sAge int default 18,

sBalary numeric(6,2) default 0,

scID int not null,

foreign key(scID) references StudentCode(scID),

unique(scID)

);

 

insert into StudentCode values(null,'123');

insert into StudentCode values(null,'456');

insert into StudentCode values(null,'789');

insert into StudentCode(scid) values(null);

insert into StudentCode values(null,'abc');

insert into Student values(null,'张三',default,1,1);

insert into Student values(null,'李四',19,0,2);

insert into Student(sid,sName,scID) values(null,'王五',3);

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/2935.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
重蔚的头像重蔚管理团队
上一篇 2017年10月23日 08:24
下一篇 2017年10月24日 12:04

相关推荐

  • (理论篇)温故而知新_PHP入门基础教程

    简单的回顾一下基础知识 1、嵌入方法: 类似ASP的<%,PHP可以是<?php或者是<?,结束符号是?>,当然您也可以自己指定。 2、引用文件: 引用文件的方法有两种:require 及 include。 require 的使用方法…

    2016年10月25日
    0688
  • 我来说说MySQL支持哪些存储引擎。

    MySQL支持的存储引擎有四种:MyISAM、InnoDB、MEMORY和ARCHIVE。MyISAM是MySQL的默认存储引擎,而InnoDB是MySQL中最常用的存储引擎之一。MyISAM适用于小型数据库,而InnoDB适用于大型数据库。MEMORY存储引擎将数据…

    2024年7月6日
    00
  • 我来分享怎么在云服务器安装数据库。

    云服务器简介 云服务器,又称为云计算服务器或弹性计算服务,是一种基于互联网的计算方式,它允许用户通过互联网连接到远程服务器,并在需要时动态分配计算资源,云服务器可以提供强大的计算能力、存储空间和带宽,…

    2024年7月25日
    00
  • mysql数据库建立数据表的练习(附代码)

    数据库操作和学习并不难,难的是如何在各种实际运用情况下编写SQL语句的实现。这个过程,需要大量的练习,那么从这里开始,我们来讲解实现。 任务概述 具体关系数据库如下:  数据库名:教师数据库 教师表(编号 cha…

    2017年10月21日
    0686
  • 分享如何修改mysql端口号。

    MySQL是一种广泛使用的开源关系型数据库管理系统,它提供了一种高效、可靠的数据存储和访问解决方案,在使用MySQL时,我们可能需要修改默认的端口号以适应特定的网络配置或安全需求,本文将详细介绍如何修改MySQL的…

    2024年6月30日
    00
  • 今日分享查看mysql是否启动。

    MySQL是一种关系型数据库管理系统,广泛应用于各种场景,在本文中,我们将讨论如何查看MySQL是否启动,我们需要了解MySQL的启动过程,当MySQL服务器启动时,它会监听一个特定的端口(默认为3306),等待客户端的连接请…

    2024年6月20日
    00
  • 宝塔面板mysql数据库无法启动的解决方法。

    今天真的是遇到的大麻烦了。本来想在服务器上再搭建一个网站的,结果不知道弄了哪里,导致了mysql数据库直接无法启动了。网上找遍了所有方法都没有解决。最后还是在一个博客上找到的解决方法。于是记录一下,方便下…

    2022年4月26日
    05.9K
  • 数据库的库操作

    库:存储数据的仓库--起名称 表:存储数据的表,一个库可以创建多个表--起名称 字段:给表中的数据起名称 记录:具体一条数据 1.创建数据库 语句:create database 数据库名 库选项; 库选项:字符集、校对集 2.查询…

    2017年11月21日 MySQL自学教程
    0175

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息