MYSQL介绍——数据库的增删改及常用函数

news/2024/5/19 11:46:04/文章来源:https://blog.csdn.net/HBUT_WANGWEI/article/details/127096035

数据操作语言——INSERT语句

Insert 语句可以向数据库中插入数据,可以是一条数据,也可以是多条数据,它有以下语法形式:
在这里插入图片描述
下面给出一个插入语法的示例:

INSERT INTO t_dept(deptno,dname,loc) VALUES(50,'司法部','济南');INSERT INTO t_dept(deptno,dname,loc) VALUES(60,'后勤部','济南'),(70,'安保部','湖北');

INSERT语句方言

MYSQL的INSERT语句还有一种方言语法
在这里插入图片描述
例如:

INSERT INTO t_dept SET deptno='80',dname='财务部',loc = '十堰';

IGNORE语法:

IGNORE关键字会让INSERT只插入数据库不存在的记录
在这里插入图片描述
例如:


INSERT IGNORE INTO t_dept(deptno,dname,loc) VALUES(60,'后勤部','济南'),(90,'HR部','湖北');

INSERT中的子查询

 INSERT语句中可以包含子查询语句,代表把子查询的内容写入到数据表
 把人数超过5人的部门记录拷贝到新的部门表
例如:

INSERT INTO t_dept_new( deptno, dname, loc )(SELECTd.deptno,d.dname,d.loc FROMt_dept dINNER JOIN ( SELECT deptno FROM t_emp e GROUP BY deptno HAVING COUNT(*)> 5 ) temp ON d.deptno = temp.deptno )

UPDATE 语句

 UPDATE语句用于修改表的记录
在这里插入图片描述
把每个员工的编号和上司的编号+1,用ORDER BY子句完成

UPDATE IGNORE t_emp 
SET empno =empno+1,
mgr =mgr+1
ORDER BY empno DESC

把月收入前三名的员工底薪减100元,用LIMIT子句完成

UPDATE t_emp
SET sal =sal-100
ORDER BY SAL DESC 
LIMIT 3

 把10部门中,工龄超过20年的员工,底薪增加200元

UPDATE t_emp 
SET SAL =sal +1000
where deptno ='10'
AND DATEDIFF(NOW(),hiredate)/365 >20

 把ALLEN调往RESEARCH部门,职务调整为ANALYST

#把ALLEN调往RESEARCH部门,职务调整为ANALYST
UPDATE t_emp E  inner join t_dept t SET E.deptno = t.deptno,JOB ='SALESMAN' WHERE t.dname ='RESEARCH' AND E.ename='ALLEN'

Mysql函数

mysql函数是指数据库将复杂一点的功能封装在函数中,供使用者使用。
在这里插入图片描述

数字函数

在这里插入图片描述

#绝对值
SELECT ABS(-100);
#四舍五入
SELECT ROUND(9.87);
#向下取整
SELECT FLOOR(9.87);
#向上取整
SELECT CEIL(9.987);
#幂函数
SELECT POWER(2,3);
#对数函数
SELECT LOG(2,2);
#对数函数
SELECT LN(2);
#开平方
SELECT SQRT(9);
#圆周率
SELECT PI();
#三角函数等
SELECT SIN(X);
#角度转弧度
SELECT RADIANS(30);
#弧度转角度
SELECT DEGREES(1);

获取系统时间函数

  • NOW()函数能获得系统日期和时间,格式yyyy-MM-dd hh:mm:ss
  • 在这里插入图片描述
  • CURDATE()函数能获得当前系统日期,格式yyyy-MM-dd
    在这里插入图片描述
  • CURTIME()函数能获得当前系统时间,格式hh:mm:ss
    在这里插入图片描述

日期格式化函数

DATE_FORMAT()函数用于格式化日期,返回用户想要的日期格式
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

#利用日期函数,查询明年你的生日是星期几?
SELECT DATE_FORMAT("2023-07-14","%W");#利用日期函数,查询1981年上半年入职的员工有多少人?
SELECT COUNT(*)
FROM t_emp 
WHERE DATE_FORMAT(hiredate,"%Y")='1981'
AND DATE_FORMAT(hiredate,"%m")<='6'

日期计算的注意事项

MySQL数据库里面,两个日期不能直接加减,日期也不能与数字加减

日期偏移运算

DATE_ADD()函数可以实现日期的偏移计算,而且时间单位很灵活
在这里插入图片描述

select DATE_ADD(NOW(),INTERVAL 10 YEAR);
select DATE_ADD(NOW(),INTERVAL 10 MONTH);
select DATE_ADD(NOW(),INTERVAL 10 DAY);
select DATE_ADD(NOW(),INTERVAL -10 YEAR);
select DATE_ADD(NOW(),INTERVAL -10 MONTH);
;select DATE_FORMAT(DATE_ADD(NOW(),INTERVAL -10 DAY),"%Y/%m/%d")

DATEDIFF()函数用来计算两个日期之间相差的天数
在这里插入图片描述

字符函数

在这里插入图片描述
在这里插入图片描述

SQL语句中可以利用条件函数来实现编程语言里的条件判断在这里插入图片描述


# 中秋节公司发放礼品,SALES部门发放礼品A,其余部门发放礼品B,打印每名员工获得的礼品SELECT E.empno,E.ename,E.empno,t.dname,IF(t.dname ='SALES',"礼品A","礼品B") AS gift
FROM t_emp E INNER JOIN t_dept T
ON E.deptno =t.deptno

在这里插入图片描述

#公司年庆决定组织员工集体旅游,每个部门旅游目的地是不同的。SALES部门去P1地点,ACCOUNTING部门去P2地点,RESEARCH部门去P3地点,查询每名员工的旅行地点
SELECT ename,
CASE D.dnameWHEN "SALES" THEN"P1"WHEN "ACCOUNTING" THEN"P2"WHEN "RESEARCH" THEN"P3"ELSE"P4"
END AS PLACE
FROM t_emp E INNER JOIN t_dept D 
ON E.deptno =D.deptno;

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

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

(附源码)springboot篮球场地预约系统 毕业设计 345655

蓝球场地预约系统的设计与实现 摘 要 传统的场地预约需要客户亲自到场地所在位置或指定地点进行&#xff0c;由于预约记录多是认为完成&#xff0c;易于出现错误和漏洞&#xff0c;管理效率低&#xff0c;特别是场地繁杂时&#xff0c;传统的预约方式已经完全不能满足要求。 远…

一文读懂 Handler 消息处理机制(源码实战)

Android 异步消息处理机制解析 Android 中的异步消息处理主要由四个部分组成&#xff0c;Message、Handler、MessageQueue、Looper 但是当我们提到 Android 异步处理机制的时候&#xff0c;我们首先会想到 Handler&#xff0c;而大多数Android 初学者对于 Handler 的作用仅局…

医院患者挂号app(IDEA,SpringBoot,SSM,MySQL)+全套视频教程

【项目功能介绍】 本系统包含后台管理和前端app双端系统&#xff0c;后台管理的功能包含: 登录, 退出, 修改管理员信息(基本信息与头像),资源管理, 角色管理&#xff0c;资源权限分配, 数据字典管理&#xff0c;用户管理,医院管理, 医生管理; app端功能包含医生与患者二种角色…

CNN中添加HOG特征的pytorch实现——基于Alexnet

CNN中添加HOG特征的pytorch实现——基于Alexnet 几天前花了差不多两天时间基本实现了这个需求&#xff0c;经历了从一开始的毫无头绪&#xff0c;到最后对CNN模型 (加载数据集和数据流向) 和HOG特征有了更进一步的理解&#xff0c;实现需求之后又杂七杂八的看了一些相关的文章…

DolphinScheduler 进阶(资源中心)

文章目录内置参数引用依赖资源内置参数 DolphinScheduler 提供了一些时间相关的系统参数&#xff0c;方便定时调度使用。 1&#xff09;基础内置参数 变量名参数说明system.biz.date${system.biz.date}定时时间前一天&#xff0c;格式为 yyyyMMddsystem.biz.curdate${system…

资深腾讯架构师耗时2个月整理的Redis全套学习笔记,涵盖所有核心知识点

Redis 是一个开源、基于内存、使用 C 语言编写的 key-value 数据库&#xff0c;并提供了多种语言的 API。它的数据结构十分丰富&#xff0c;基础数据类型包括&#xff1a;string&#xff08;字符串&#xff09;、list&#xff08;列表&#xff0c;双向链表&#xff09;、hash&a…

18【命令设计模式】

文章目录十八、命令设计模式18.1 命令设计模式简介18.1.1 命令设计模式概述18.1.2 命令设计模式的UML类图18.2 命令设计模式的实现18.3 命令设计模式的优缺点十八、命令设计模式 18.1 命令设计模式简介 18.1.1 命令设计模式概述 命令设计模式&#xff08;Command Pattern&am…

元宇宙人均月入过万?智联报告大揭秘(附下载);华盛顿大学·线性代数进阶课程;电子书·深度神经网络应用(Keras);前沿论文 | ShowMeAI资讯日报

&#x1f440;日报合辑 | &#x1f4c6;电子月刊 | &#x1f514;公众号下载资料 | &#x1f369;韩信子 &#x1f4e2; 人均『月入过万』&#xff1f;元宇宙领域就业现状究竟如何 自2021年元宇宙元年之后&#xff0c;大批元宇宙相关岗位如雨后春笋涌现在市场上。从耳熟能详的…

罗克韦尔 Rockwell RSLogix 500 Crack

罗克韦尔自动化除了提供自动化基础硬件外&#xff0c;还提供大量的软件工具&#xff0c;并在其产品中包含了最新的Microsoft的32位Windows NT及ActiveXTM技术。这些软件为用户采用开放式的工业标准提供方便。另外借助DDE、ActiveX和ODBC兼容技术等&#xff0c;使现场数据能容易…

Chrome 浏览器的 ChromeOptions 参数介绍,selenium 动态渲染必看

背景 在使用 selenium 浏览器渲染技术&#xff0c;爬取网站信息时&#xff0c;默认情况下就是一个普通的纯净的chrome浏览器&#xff0c;而我们平时在使用浏览器时&#xff0c;经常就添加一些插件&#xff0c;扩展&#xff0c;代理之类的应用。相对应的&#xff0c;当我们用ch…

SpringBoot+SpringSecurity+JWT

声明&#xff1a; 该文章为b站博主“三更草堂”视频讲解文档。 视频链接&#xff1a; https://www.bilibili.com/video/BV1mm4y1X7Hc/?spm_id_from333.1007 文章目录SpringSecurity从入门到精通课程介绍0. 简介1. 快速入门1.1 准备工作1.2 引入SpringSecurity2. 认证2.1 登陆校…

Windows系统深度学习Anaconda、PyTorch软件安装教程

1.作者介绍 陈梦丹&#xff0c;女&#xff0c;西安工程大学电子信息学院&#xff0c;2022级研究生&#xff0c;张宏伟人工智能课题组 研究方向&#xff1a;机器视觉与人工智能 电子邮件&#xff1a;1169738496qq.com 安装思路&#xff1a; 根据电脑显卡选择cuda版本&#xf…

软件供应链中代码签名的重要性

你怎麼知道你的代碼是可信的&#xff1f; 在一個難以獲得信任的世界裡&#xff0c;這是一個重要的問題要問自己。 我們如何知道我們正在運行的應用程序、我們正在部署的容器或我們交付給客戶的代碼是真實的&#xff1f; 我們怎麼知道它沒有被篡改&#xff1f; 這一切都歸結為…

VUE3-实习笔记02

本节&#xff1a;ant design 3 的自定义校验规则 这里是获取数据&#xff0c;保存数据&#xff0c;有两个接口&#xff0c;测试邮箱的校验是非必要的&#xff0c;点击“发送测试邮件”才校验&#xff0c;所以规则是要另外加进去的&#xff0c;然后点击保存的时候&#xff0c;把…

python基本操作的作业

查看变量类型的Python内置函数是____。type () 返回单字符在unicode编码表中的值的函数为____。ord() Python中的布尔型只有两个值&#xff0c;分别为&#xff1a;____和____。True 和 False 执行下列语句后&#xff0c;从键盘输入10&#xff0c;程序的结果是&#xff1a; 1…

ActiveReportsJS 在 React 应用程序中添加和自定义查看器

谷歌搜破解版&#xff1a;ActiveReportsJS 3.2中文版是一个客户端报告解决方案&#xff0c;可用于各种不同的前端框架和库。从 vanilla JavaScript 到 NuxtJS&#xff0c;ARJS 在设计应用程序和使用其组件时非常灵活。在本文中&#xff0c;我们将讨论如何通过 Visual Studio Co…

Delphi 开发过程中简单的版本管理与回退

前言 很多时候&#xff0c;我们在进行代码编写或者窗体设计的时候&#xff0c;如果需要回退某些早前修改的内容&#xff0c;基本是使用CtrlZ做刚刚修改内容的回退处理&#xff0c;但如果某些修改已经过了一段时间我们就不能再这样退回&#xff0c;并且CtrlZ只能按顺序一个一个回…

用QT的modbus相关类编写ModbusTcp主站

目标程序运行界面&#xff0c; 1.新建Qwiget工程&#xff0c;工程文件如下&#xff0c; #------------------------------------------------- # # Project created by QtCreator 2022-09-28T14:53:02 # #------------------------------------------------- QT co…

MYSQL介绍——数据库查询

条件查询 很多时候&#xff0c;我们使用数据库时并不是关心表里所有的数据&#xff0c;而是一部分满足条件的数据&#xff0c;这类条件要用WHERE子 句来实现数据的筛选。 SELECT …… FROM …… WHERE 条件 [ AND | OR ] 条件 …… ;下面给出一个示例&#xff1a; SELECT * …

Android init.rc语言全解析

读懂init语言并不难,难的是有人愿意去做这个事情然后分享出来,如果不是接触到这块的知识,没有谁会专门研究这个,这也是为什么我写第一篇initrc文章到现在过去了7年多了一直没更新的原因,经常有小伙伴私信我希望我写一篇关于init文件解读的文章,或者是想请教下如何在custo…