3.1 数据表的基本查询

news2024/9/20 13:55:51

我们学习的怎么管理逻辑空间,怎么创建数据表,怎么定义字段,怎么创建索引,这些都是DDL语句。从本次课开始,我们来学习DML语句,也就是该如何增删改查操作数据。我们学习DML语句的前提是数据表要有足够多的数据,之前我们在学习DDL语句的时候虽然说创建了一些数据表,但是数据表中的记录都太少了,所以我写好了一个SQL文件,里面有创建数据表和一些初始数据供我们学习使用,只需要执行这个sql文件就可以了,那接下来,我把这个sql文件中的数据表和数据导入到咱们mysql数据库里边,那么为了避免和已经存在的数据表发生冲突,我把的数据表和新的数据都保存在新的逻辑空间里边。

一、sql源文件导入sql的过程

新建数据库--填写新数据库名称--运行sql文件--选择demo文件--开始运行--刷新

二、数据表表格说明

t_dept部门表:只有3个字段来构成,比如说第一个字段叫做 deptno是部门的编号,那么有4条数据,它的部门编号儿分别是10,20,30,40,二个字段,这个字段叫做dname字段,是部门的名称,有的部门儿叫做accounting, accounting,有的部门儿叫research。loc,它的全称叫做location,就是地点,有的部门儿是在纽约,有的部门儿在达拉斯,有的部门儿在芝加哥,有的部门儿在波士顿。

t_emp员工表:第一个字段叫做empno,不用说这个是员工的编号,肯定是主键字段。

然后再往下还有是ename,这个是员工的名字,下面一个字段是job员工的职务,mgr这个字段是当前这个员工的上司的员工编号,比如说这个7369这个人,他的上司的员工编号儿是7902。hiredate,这个字段是员工的入职日期,你可以看都是198几年的这个日期都比较早。sal字段,sal字段就是月薪,你的这个月薪是多少钱?比如说有800美金的,有1600美金的。还有一个字段叫comm字段,这个字段是佣金字段,那咱们来看有的人这个佣金是300美金,有的这个人的佣金是500美金,有的人还没有佣金。最后一个字段叫做deptno,不用说了,这个是我们员工的部门编号,它是和部门表的那个主键字段产生关联关系的对吧?这个叫做deptno

t_salgrade工资等级表:这个表是工资等级表,一共是有5条记录,那么这个工资等级表就记录着说这个工资的分级级,比如说第一级的这个工资,他的最低工资是700美金到1200美金。二级的这个工资是1201美金到1400美金,所以以此类推,这个我就不说了,这个是工资等级表

t_bonus奖金表:有这个员工的编号,还有职务,还有是他的这个底薪是多少钱,然后再有的话是他的这个佣金是多少钱等我们将来在练习增删改查操作的时候,可以往这张数据表里面填写新的记录

三、select查询

我们先从数据的查询开始说起,最基本的查询语句是由select和from关键字来组成的。

比如说,我现在想查询员工表的信息,这个sql语句就是select from,然后t_emp,然后加上分号结尾就行了,from子句规定的是从员工表中查询数据

如果想看结果集中所有字段:select子句中的这个*,代表说在结果集里边显示员工表儿的所有字段的意思,

如果说你不想查找所有的字段:在结果集里边只需要列出来你想要的字段,那在这个select里边,比如我只想看到员工的编号员工的姓名,还有员工的底薪,那你把这3个字段的名称写上就能写上就可以了

select语句屏蔽了物理层的数据查找,让用户不必关心数据的存储方式,查询工作交给数据库系统去完成,短短的一条sql语句就能从成千上万的数据中检索到我们需要的记录,真的是太方便了,接下来我把刚才的sql语句去执行一下,首先是要切换到demo这个逻辑空间里的,然后才能执行相关的这个查询语句,比如说我现在查询一下这个表员工表所有的这个信息,那么select语句里面写了一个*,就是这个员工表儿里面所有的字段。在结果集里边都需要出现各位同学可以看下面的这些查询的结果集,就是我们想要的员工信息了,果真是所有的字段都打印出来了对吧?如果说我们现在想特殊的查找某一些字段的话,那在这里边我把select去修改一下。

比如说我想查找的是员工的编号,empno,姓名name,还有是员工的底薪sql,好了,那我把这个sql语句选中,然后咱们来执行一下,在结果集里边果真显示的字段就是我们规定的那3个字段

USE sql文件  #选择刚刚导入的sql文件

SELECT * FROM t_dept  # 查询t_dept部门表全部字段
SELECT ename,job,sal FROM t_emp  # 查询t_emp员工表员工姓名,工作,薪资字段

四、select使用列别名

mysql提供了给结果集中字段重命名的语法,特别是那些使用了表达式的字段列名,就是表达式本身,所以就需要修改,接下来咱们看下面的sql语句

比如说我现在想查询每名员工的年收入情况,然后selects句里边显示的字段empno,那么年收入的话,我就是把这个sal*12,这个就是一年的这个基本工资的一个收入,然后如果说你不给字段起别名的话,那么一会显示的结果集里边这个字段的名字就叫做sal*12,所以说看起来非常的不优雅,那接下来我们可以用这个重命名的这个语法,给这个字段起一个新的名字,这个重命名的语法就是在后面加上一个as的这个关键字,关键字当然你不写as也可以,写上空格就行了,然后后面跟上这个income,这就是一个别名

# 使用别名计算员工年薪
SELECT
  empno,ename,sal*12 as "income"
FROM t_emp;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2149084.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Moving Elevator System Fully functional

这是一个功能齐全的电梯系统,配有电梯箱车、电梯井、电缆和每层的门框 电梯完全被操纵,有动画门、电缆线、滑轮系统。 还有几个C#脚本文件控制电梯、门和灯。 此套餐还包括相关声音,如电梯移动、门打开/关闭、楼层铃叮。 电梯车厢有工作门和按钮,车顶还有一个逃生舱口。 每…

低投入、高效率 基于PHP+MySQL组合开发的求职招聘小程序源码系统 带完整的安装代码包以及搭建部署教程

系统概述 这款求职招聘小程序源码系统是专门为求职招聘领域打造的综合性平台。它利用 PHP 强大的编程语言特性和 MySQL 稳定的数据存储功能,实现了一个功能齐全、性能优越的求职招聘系统。 整个系统架构设计合理,具备良好的扩展性和兼容性。无论是小型…

从《中国数据库前世今生》看中国数据库技术的发展与挑战

从《中国数据库前世今生》看中国数据库技术的发展与挑战 引言 在当今数字化浪潮中,数据库技术已成为支撑全球经济运行的核心基础设施。作为程序员,我一直对数据库技术的发展充满好奇。《中国数据库前世今生》纪录片深入探索了中国数据库技术的演变历程…

【Python报错已解决】libpng warning: iccp: known incorrect sRGB profile

🎬 鸽芷咕:个人主页 🔥 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想,就是为了理想的生活! 专栏介绍 在软件开发和日常使用中,BUG是不可避免的。本专栏致力于为广大开发者和技术爱好者提供一个关于BUG解决的经…

怎么把图片压缩变小?把图片压缩变小的八种压缩方法介绍

怎么把图片压缩变小?在当今这个信息高度共享的时代,图片不仅仅是简单的视觉元素,它们承载着我们的记忆、故事和创意。无论是旅行的风景、家庭的聚会,还是工作中的项目展示,图片都在我们的生活中扮演着不可或缺的角色。…

帕金森患者必看!这5种水果成“抗抖”小能手,吃出健康好生活!

在这个快节奏的时代,健康成为了我们最宝贵的财富之一。而对于帕金森病患者而言,如何在日常生活中通过合理的饮食来缓解症状、提升生活质量,成为了许多家庭关注的焦点。今天,就让我们一起探索那些被誉为“抗抖”小能手的水果&#…

Pandas -----------------------基础知识(一)

目录 Series对象 属性和方法 布尔值列表获取Series对象中部分数据 运算 DateFrame对象 常用属性 常见方法 运算 总结 Series对象 是DataFrame的列对象或者行对象 生成Series对象生成索引使用元组创建Series对象使用字典创建Series对象 通过Pandas创建对象 自定义索引 …

RealityCapture1.4设置成中文

RealityCapture 1.4 设置成中文的教程 RealityCapture 1.4 是一款强大的三维建模软件,它能够从图像或激光扫描中创建实景三维模型和正射影像等。以下是一个详细的教程,指导您如何将 RealityCapture 1.4 的界面设置为中文。 1.找到设置按钮 在WORKFLOW…

【一起学NLP】Chapter1-基本语法与神经网络的推理

备注:本专栏为个人的NLP学习笔记,欢迎大家共同讨论交流学习。代码同步:https://github.com/codesknight/Learning-NLP-Together 参考书籍:《深度学习进阶:自然语言处理》——斋藤康毅 目录 基础知识点复习测试环境使用…

OceanMesh2D | 基于精确距离的沿海海洋/浅水流动模型二维自动网格生成MATLAB工具箱推荐

Precise distance-based two-dimensional automated mesh generation toolbox intended for coastal ocean/shallow water flow models OceanMesh2D | 基于精确距离的沿海海洋/浅水流动模型二维自动网格生成MATLAB工具箱推荐 1. 简介2. 特点3. 代码基本要求:4. 基本流程 1. 简…

一、Numpy使用

1、numpy的简单使用 import numpy as np #利用as给numpy起一个别名np# 使用array来承接这个数组 array np.array([[1,2,3],[2,3,4]])print(array) print("number of dim:", array.ndim) # ndim 数组维度 print("shape:", array.shape) # 数组的形…

c++编程(27)——IO流(1)

欢迎来到博主的专栏&#xff1a;c编程 博主ID&#xff1a;代码小豪 文章目录 标准IO流标准输入输出cincin的四个状态标志 标准IO流 <iostream>库中的IO类在之前已经经常使用了&#xff0c;但是我们还从未仔细的了解过。在c标准库中&#xff0c;IO类分为两种&#xff0c;…

sqli-labs靶场自动化利用工具——第2关

文章目录 概要整体架构流程技术细节执行效果小结 概要 Sqli-Labs靶场对于网安专业的学生或正在学习网安的朋友来说并不陌生&#xff0c;或者说已经很熟悉。那有没有朋友想过自己开发一个测试脚本能实现自动化化测试sqli-labs呢&#xff1f;可能有些人会说不是有sqlmap&#…

摄影社团管理系统

基于springbootvue实现的摄影社团管理系统 &#xff08;源码L文ppt&#xff09;4-075 第四章 系统概要设计 4.1系统设计原理 设计原理是指系统的设计来源&#xff0c;它将需求合理地分解为功能&#xff0c;并抽象地描述系统的模块和其下的功能。在功能模块化后&#xff…

【数据结构】排序算法---桶排序

文章目录 1. 定义2. 算法步骤3. 演示3.1 动态演示13.2 动态演示23.3 图片演示13.4 图片演示2 4. 性质5. 算法分析6. 代码实现C语言PythonJavaCGo 结语 1. 定义 桶排序&#xff08;英文&#xff1a;Bucket sort&#xff09;是计数排序的升级版&#xff0c;适用于待排序数据值域…

【算法】最长公共子序列(C/C++)

最长公共子序列&#xff08;LCS&#xff0c;Longest Common Subsequence&#xff09;问题简称&#xff08;LCS&#xff09;&#xff0c;是动态规划里面里面的基础算法。它的所解决的问题是&#xff0c;在两个序列中找到一个序列&#xff0c;使得它既是第一个序列的子序列&#…

SpringCloud微服务实现服务降级的最佳实践

Spring Cloud是一种用于快速构建分布式系统的框架&#xff0c;它提供了许多有用的功能&#xff0c;其中包括服务降级。 服务降级是一种保护机制&#xff0c;它可以在面临高并发或故障时保持服务的稳定性。当系统资源不足或服务出现故障时&#xff0c;服务降级可以通过关闭一些功…

2.计算机网络基础

2. 计算机网络基础 (1) 计算机网络的定义 计算机网络是指将地理位置不同、具有独立功能的多个计算机系统通过通信线路和设备连接起来,以功能完善的网络软件实现网络中资源共享的系统。最简单的定义是:计算机网络是一些互相连接的、自治的计算机系统的集合。最庞大的计算机网…

MATLAB系列03:分支语句和编程设计

MATLAB系列03&#xff1a;分支语句和编程设计 3. 分支语句和编程设计3.1 自上而下的编程方法简介3.2 伪代码的应用3.3 关系运算符和逻辑运算符3.3.1 关系运算符3.3.2 小心和~运算符3.3.3 逻辑运算符3.3.4 逻辑函数 3.4 选择结构3.4.1 if结构3.4.2 switch结构3.4.3 try/catch结构…

c++的decltype关键字

它可以将变量声明为表达式指定的类型