您当前的位置: 首页 >  数据库

import java.lx

暂无认证

  • 3浏览

    0关注

    81博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

DQL操作(数据库表数据查询操作)

import java.lx 发布时间:2022-08-31 19:56:46 ,浏览量:3

DQL数据查询语言

数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。

查询返回的结果集是一张虚拟表。

查询关键字:SELECT 语法:

 SELECT 列名 FROM表名

【WHERE --> GROUP BY -->HAVING--> ORDER BY-->LIMIT】

语法:

SELECT selection_list /*要查询的列名称*/

FROM table_list /*要查询的表名称*/

WHERE condition /*行条件*/

GROUP BY grouping_columns /*对结果分组*/

HAVING condition /*分组后的行条件*/

ORDER BY sorting_columns /*对结果分组*/

LIMIT offset_start, row_count /*结果限定*/

以该案例分析查询语句:

#创建数据库Study
CREATE DATABASE Study
#使用数据库Study
USE Study

#创建表stu
CREATE TABLE `stu` (
`sid`	CHAR(6),
`sname`	VARCHAR(50),
`age`	INT,
`gender`VARCHAR(50)
);

#向stu表中插入数据
INSERT INTO stu VALUES('S_1001', 'liuYi', 35, 'male');
INSERT INTO stu VALUES('S_1002', 'chenEr', 15, 'female');
INSERT INTO stu VALUES('S_1003', 'zhangSan', 95, 'male');
INSERT INTO stu VALUES('S_1004', 'liSi', 65, 'female');
INSERT INTO stu VALUES('S_1005', 'wangWu', 55, 'male');
INSERT INTO stu VALUES('S_1006', 'zhaoLiu', 75, 'female');
INSERT INTO stu VALUES('S_1007', 'sunQi', 25, 'male');
INSERT INTO stu VALUES('S_1008', 'zhouBa', 45, 'female');
INSERT INTO stu VALUES('S_1009', 'wuJiu', 85, 'male');
INSERT INTO stu VALUES('S_1010', 'zhengShi', 5, 'female');
INSERT INTO stu VALUES('S_1011', 'xxx', NULL, NULL);

#创建表emp
CREATE TABLE emp(
	empno		INT,
	ename		VARCHAR(50),
	job		VARCHAR(50),
	mgr		INT,
	hiredate	DATE,
	sal		DECIMAL(7,2),
	comm		DECIMAL(7,2),
	deptno		INT
) ;

#向emp表中插入数据
INSERT INTO emp VALUES(7369,'SMITH','CLERK',7902,'1980-12-17',800,NULL,20);
INSERT INTO emp VALUES(7499,'ALLEN','SALESMAN',7698,'1981-02-20',1600,300,30);
INSERT INTO emp VALUES(7521,'WARD','SALESMAN',7698,'1981-02-22',1250,500,30);
INSERT INTO emp VALUES(7566,'JONES','MANAGER',7839,'1981-04-02',2975,NULL,20);
INSERT INTO emp VALUES(7654,'MARTIN','SALESMAN',7698,'1981-09-28',1250,1400,30);
INSERT INTO emp VALUES(7698,'BLAKE','MANAGER',7839,'1981-05-01',2850,NULL,30);
INSERT INTO emp VALUES(7782,'CLARK','MANAGER',7839,'1981-06-09',2450,NULL,10);
INSERT INTO emp VALUES(7788,'SCOTT','ANALYST',7566,'1987-04-19',3000,NULL,20);
INSERT INTO emp VALUES(7839,'KING','PRESIDENT',NULL,'1981-11-17',5000,NULL,10);
INSERT INTO emp VALUES(7844,'TURNER','SALESMAN',7698,'1981-09-08',1500,0,30);
INSERT INTO emp VALUES(7876,'ADAMS','CLERK',7788,'1987-05-23',1100,NULL,20);
INSERT INTO emp VALUES(7900,'JAMES','CLERK',7698,'1981-12-03',950,NULL,30);
INSERT INTO emp VALUES(7902,'FORD','ANALYST',7566,'1981-12-03',3000,NULL,20);
INSERT INTO emp VALUES(7934,'MILLER','CLERK',7782,'1982-01-23',1300,NULL,10);

#创建表dept
CREATE TABLE dept(
	deptno		INT,
	dname		VARCHAR(14),
	loc		VARCHAR(13)
);

#向dept表中插入数据
INSERT INTO dept VALUES(10, 'ACCOUNTING', 'NEW YORK');
INSERT INTO dept VALUES(20, 'RESEARCH', 'DALLAS');
INSERT INTO dept VALUES(30, 'SALES', 'CHICAGO');
INSERT INTO dept VALUES(40, 'OPERATIONS', 'BOSTON');
1.基础查询

查询所有字段

查询表中的所有字段:第一种方式将所有的字段一一写出来,第二种,使用*表示所有的字段

SELECT * FROM 表名;

查询指定字段

SELECT 字段名1,字段名2,......字段名n FROM 表名;
2.条件查询

条件查询就是对查询出来的结果进行筛选,使用WHERE进行过滤

在WHERE子句中可以使用如下运算符及关键字:

  1. =、!=、、=;
  2. BETWEEN…AND;
  3. IN(set);
  4. IS NULL;IS NOT NULL:  
  5. AND;
  6. OR;
  7. NOT;

 

#查询性别为女,并且年龄小于50的记录(记录:表示查询所有的字段)
SELECT * FROM stu WHERE gender ='female' AND age=20 AND age 2500;
#统计月薪与佣金之和大于2500元的人数
#查询出月薪和佣金之和大于2500的员工记录
SELECT * FROM emp WHERE sal+IFNULL(comm,0)>2500;
SELECT COUNT(*) '月薪与佣金之和大于2500元的人数' FROM emp WHERE sal+IFNULL(comm,0)>2500;
#查询有佣金的人数,以及有领导的人数:
SELECT COUNT(comm) '有佣金的人数',COUNT(mgr) '有领导的人数' FROM emp;
#sum()和avg()函数
#查询所有雇员月薪和:
SELECT SUM(sal) AS'所有雇员月薪和' FROM emp;
#查询所有雇员月薪和,以及所有雇员佣金和
SELECT SUM(sal)'所有雇员月薪和',SUM(comm)'所有雇员佣金和' FROM emp;

#查询所有雇员月薪+佣金和
SELECT SUM(sal+IFNULL(comm,0)) '所有雇员月薪+佣金和' FROM emp;
#统计所有员工平均工资
SELECT AVG(sal)'所有员工平均工资' FROM emp;
#查询最高工资和最低工资:
SELECT MAX(sal) '最高工资',MIN(sal) '最低工资' FROM emp;

MySQL数据库中除了提供上述聚合函数外,还有很多的函数提供给我们使用,比如:

SELECT CONCAT('Hello','world','welcom','to','China');#合并多个字符串
SELECT LOWER('qwertyuiop');#将字符串的所有字母变成小写字母
SELECT UPPER('asdfghjkl');#将字符串转换为大写
SELECT RAND();#	返回 0 到 1 的随机数 
SELECT ADDDATE("2022-08-31",INTERVAL 30 DAY);#计算起始日期 d 加上 n 天的日期
SELECT CURDATE();#	返回当前日期
SELECT CURRENT_TIME();#返回当前时间
SELECT DATEDIFF('1949-10-01','2022-08-31');#计算日期 d1->d2 之间相隔的天数
SELECT BIN(16);#返回 x 的二进制编码

可以去浏览器搜索菜鸟教程学习相关知识 

关注
打赏
1663829786
查看更多评论
立即登录/注册

微信扫码登录

0.7425s