学习测试8-数据库mysql操作

下载配置mysql

网络博客

使用

在Linux里

1 service mysql start 启动服务

2 在Navicatt 中连接Linux服务器
请添加图片描述

3

第一步
将所有文件上传到/opt目录下
第二步
chmod 777 deploy-mysql.sh
第三步
./deploy-mysql.sh

4 service mysql status 查看状态是否安装成功
请添加图片描述

5 重启mysql服务
service mysql restart
请添加图片描述

– 关闭mysql服务 这个命令,同1的server命令
/etc/init.d/mysql stop
– 启动mysql服务
/etc/init.d/mysql start


sql语句

创建表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
#创建银行客户信息表
use bankDB;
CREATE TABLE IF NOT EXISTS userInfo(
	customerID INT(8) PRIMARY KEY AUTO_INCREMENT COMMENT '客户编号',
	customerName VARCHAR(10) NOT NULL COMMENT '开户姓名',
	PID CHAR(18) NOT NULL COMMENT '身份证编号',
	telephone CHAR(11) NOT NULL COMMENT '手机号码',
	address VARCHAR(50) COMMENT'地址'
)ENGINE=INNODB CHARSET=utf8 COMMENT='银行客户信息表';

简单sql - 查询

-- 查表
SELECT * FROM userInfo; 
--查address是上海
SELECT * FROM userInfo WHERE address ='上海';

--查id是4
SELECT * FROM userInfo WHERE id=4;
--查不是4
SELECT * FROM userInfo WHERE id<>4;
--查address不是上海,<>可以用于数字,也可以是字符
SELECT * FROM userInfo WHERE address<>'上海';

-- between ..and  ..   查id在3和5之间
SELECT * FROM userInfo WHERE id between 3 and 5;

-- in  包含多个无规律的
SELECT * FROM userInfo WHERE customerID  IN (1,3,4);
SELECT * FROM userInfo WHERE customerName  IN ('刘流','丁强');

-- 模糊查询 查以上海开头
SELECT * FROM userInfo WHERE address like '上海%';
-- 模糊查询 查以海开头,两个字的     _为占位符
SELECT * FROM userInfo WHERE address like '海_';
-- 模糊查询 查以开头第二个字是海的     _为占位符
SELECT * FROM userInfo WHERE address like '_海%';
-- 模糊查询 查以倒数第二个字是海结尾的     _为占位符
SELECT * FROM userInfo WHERE address like '%海_';

-- 模糊查询 查以浦东结尾
SELECT * FROM userInfo WHERE address like '%浦东';
-- 模糊查询 查带海字的
SELECT * FROM userInfo WHERE address like '%海%';

逻辑运算符 and or not
--查address是上海,同时id 大于 2       and用于多条件
SELECT * FROM userInfo WHERE address='上海' and id > 2;

--查address是带海字的,或者 id 大于 1       or是或
SELECT * FROM userInfo WHERE address like '%海%' or customerID > 1;

--查id不等于4
SELECT * FROM userInfo WHERE not id=4;

排序 order by asc 正序 desc 倒序
-- 将表以money 的正序,从小到大排序     asc可以不写
select * from tradeInfo order by money asc

-- 将表以money 的逆序,从大到小排序     asc可以不写
select * from tradeInfo order by money desc

-- 将表以多列排序    先对第一列排列,有相同的再第二列排,,
select * from tradeInfo order by transMoney ASC,cardID DESC;

-- 查询1010开头,1130结尾的银行卡的交易记录,结果按照交易时间降序排序
SELECT * FROM tradeInfo WHERE tradeInfo.cardID like '1010%' AND cardID LIKE '%1130' ORDER BY transDate ;

聚合函数 MAX MIN SUM AVG COUNT
-- MAX()函数返回指定列中的最大值
SELECT max(transMoney) FROM tradeInfo;

-- MIN()函数返回指定列中的最小值
SELECT MIN(transMoney) FROM tradeInfo;

-- SUM()是一个求总和的函数,返回指定列值的总和
SELECT SUM(transMoney) FROM tradeInfo;

-- AVG()指定列数据的平均值
SELECT AVG(transMoney) FROM tradeInfo;

-- COUNT()函数统计表中包含的记录行的总数,或根据查询结果返回列中包含的数据行数
SELECT COUNT(transMoney) FROM tradeInfo;

单组函数 YEAR MONTH DAY REPLACE SUBSTR IFNULL
-- YEAR()取单列的年月日
SELECT YEAR(transDate) FROM tradeInfo;
SELECT MONTH(transDate) FROM tradeInfo;
SELECT DAY(transDate) FROM tradeInfo;

-- replace()替换   字段名  要替换的   替换成
-- 并未真的改动表,只是改显示
SELECT REPLACE(tradeInfo.transType,'存入','存钱') FROM tradeInfo

--  SUBSTR() 截取字段   1 是从第一位开始,5 是截取长度为5位
SELECT SUBSTR(cardInfo.cardID ,1,5) FROM tradeInfo;

-- IFNULL 判断为空替换值   字段名,空被替换成
SELECT IFNULL(openmoney,10) FROM cardInfo;

分页 limit
-- limit  n  查询前多少行
SELECT * FROM tradeInfo LIMIT 5;

-- limit 查询4到9行     3是从第三行后开始,6是取六行
SELECT * FROM tradeInfo LIMIT 3,6;
先排序再分页 where order by limit
-- 查询1130结尾的银行卡的交易记录,结果按照交易时间降序排序,显示4行
SELECT * FROM user WHERE userId LIKE '%30' ORDER BY transDate  limit 4 ;
练习
-- 练习:
-- 1)统计有多少个用户
SELECT COUNT(userInfo.customerID) FROM userInfo;

-- 2)统计银行卡信息表中有多少张银行卡
SELECT COUNT(cardInfo.cardID) FROM cardInfo;

-- 3)统计交易信息表中总共有多少笔交易
SELECT COUNT(tradeInfo.transDate) FROM tradeInfo;

-- 4)统计存款种类表中有多少中存款类型  
SELECT COUNT(deposit.savingID) FROM deposit;

-- 1)查询所有9月份的交易记录  
SELECT * FROM tradeInfo WHERE MONTH(transDate) = 9 ;

-- 2)将姓名中带有强的用户姓名替换成强强
SELECT REPLACE(userInfo.customerName,'强','强强') FROM userInfo;

-- 6)查询交易信息表中,所有交易时间(只要返回几月几号)比如2020-12-11 12:00:00 只需要返回12-11
SELECT MONTH(transDate),DAY(transDate) FROM tradeInfo ;

-- 7)查询丁强和王旺两个客户手机号后4位
SELECT SUBSTR(userInfo.telephone,7,4) FROM userInfo WHERE userInfo.customerName IN("丁强","王旺");

-- 1)查询交易金额最高的银行卡号(用limit)
SELECT tradeInfo.cardID FROM tradeInfo ORDER BY transMoney DESC LIMIT 1;

-- 2)查询存款余额前三名的银行卡信息
SELECT * FROM cardInfo ORDER BY cardInfo.balance DESC LIMIT 3;

-- 3)查询做的支取交易,按照交易金额排序,最小的三个银行卡号
SELECT cardID FROM tradeInfo WHERE tradeInfo.transType = '支取' ORDER BY transMoney LIMIT 3;

-- 4)查询交易信息表中,存入金额是第2高到第5高的交易
SELECT * FROM tradeInfo WHERE transType = '存入' ORDER BY transMoney DESC LIMIT 1,4;

分组 对某一类分组 group by 配合函数一起用

只能查询显示到分组的那一组

-- 对存取类型transType 分组,只能查看分组类型这一列
SELECT transType FROM tradeInfo GROUP BY transType;

--  查询每张卡交易的最大金额、最小金额
SELECT cardID,MAX(transMoney),min(transMoney) FROM tradeInfo GROUP by tradeInfo.cardID;

--  查询存入交易的总金额
SELECT cardID,SUM(transMoney) FROM tradeInfo WHERE transType = '存入' GROUP by tradeInfo.cardID;

--  查询2023-05-06日支取交易金额的最大值和和最小值     先筛,再分
-- WHERE transDate like '2023-05-06%' 也可以
SELECT cardID,MAX(transMoney),MIN(transMoney)FROM tradeInfo WHERE SUBSTR(transDate,0,10) ='2023-05-06' AND transType ='支取' GROUP by cardID;

先分组,再进行筛选 group by 列名 having 过滤条件

请添加图片描述

-- 所有成绩都及格的学生
SELECT stuName FROM stu GROUP by stuName HAVING min(score) >= 60;

-- 没有学生不及格的科目
SELECT 科目 FROM stu GROUP by 科目 HAVING score >= 60;

-- 成绩最低都是80 的学生
SELECT stuName FROM stu GROUP by stuName HAVING min(score) >= 80;
多重分组 GROUP by x,x2

请添加图片描述

-- 每轮所有成绩都及格的学生   先以姓名分组,再以轮次分组
SELECT 姓名 FROM stu GROUP by 姓名,轮次 HAVING min(score) >= 60;

多表联查

在这里插入图片描述

-- 1)查询交易金额大于2000的用户姓名和手机号
-- 方法1
-- SELECT userInfo.cardID FROM userInfo WHERE userInfo = (SELECT cardID FROM tradeInfo WHERE tradeInfo.transMoney > 2000)
-- 方法2
SELECT customerName,telephone FROM cardInfo,userInfo,tradeInfo WHERE cardInfo.customerID = userInfo.customerID AND cardInfo.cardID = tradeInfo.cardID AND tradeInfo.transMoney > 2000;


-- 2)查询支取交易金额大于400的用户姓名和手机号
SELECT customerName,telephone FROM cardInfo,userInfo,tradeInfo WHERE cardInfo.customerID = userInfo.customerID AND cardInfo.cardID = tradeInfo.cardID AND transType = '支取' AND transMoney >400;


--  查询账户余额大于5000的客户姓名
SELECT userInfo.customerName FROM userInfo WHERE userInfo.customerID = (SELECT customerID FROM cardInfo WHERE cardInfo.balance > 5000);

--  存款方式为1的账户的交易金额
SELECT transMoney FROM tradeInfo WHERE tradeInfo.cardID IN (SELECT cardID FROM cardInfo WHERE cardInfo.savingID =1);

删除新表

drop table tabname

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

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

相关文章

WPS打开PDF文件的目录

WPS打开PDF文件的目录 其实WPS中PDF文件并没有像Word那样标准的目录&#xff0c;但是倒是有书签&#xff0c;和目录一个效果 点击左上角书签选项&#xff0c;或者使用Alt Shift 1快捷键即可

『Django』自带的后台

theme: smartblue 本文简介 点赞 关注 收藏 学会了 上一篇讲了 Django 操作 MySQL 的方法&#xff0c;讲了如何创建模型&#xff0c;如何对数据库做增删改查的操作。但每次修改数据都要写代码&#xff0c;多少有点麻烦。 有没有简单一点的方法呢&#xff1f; 有的有的&#…

centos 安装ffmpeg

这个错误表明在你的 CentOS 系统的默认仓库中没有 ffmpeg 包。CentOS 的默认仓库通常不包含 ffmpeg&#xff0c;因为它涉及一些许可证问题。但是&#xff0c;你可以通过添加第三方仓库来安装 ffmpeg。 使用 EPEL 和 RPM Fusion 仓库 # 安装 EPEL 仓库 sudo yum install epel-…

苹果入局,AI手机或将实现“真智能”?

【潮汐商业评论/原创】 “AI应用智能手机不就是现在的AI手机。” 当被问到现阶段对AI手机的看法时&#xff0c;John如是说。“术业有专攻&#xff0c;那么多APP在做AI功能&#xff0c;下载用就是了&#xff0c;也用不着现在换个AI手机啊。” 对于AI手机&#xff0c;或许大多…

Windows中安装部署MinIo文件系统,在Spring Boot中引入MinIo依赖实现上传文件到MinIo文件系统中

minio安装部署可以看这篇教程&#xff1a;https://blog.csdn.net/qq_43108153/article/details/134016896 创建桶 将私有设置成公开 导入依赖 <!-- minio --> <dependency><groupId>io.minio</groupId><artifactId>minio</artifactId>…

【正点原子K210连载】第二十一章 machine.UART类实验摘自【正点原子】DNK210使用指南-CanMV版指南

1&#xff09;实验平台&#xff1a;正点原子ATK-DNK210开发板 2&#xff09;平台购买地址https://detail.tmall.com/item.htm?id731866264428 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/docs/boards/xiaoxitongban 第二十一章 machine.…

Java中HashMap详解:hash原理、扩容机制、线程不安全及源码分析

前言 HashMap 是 Java 中常用的数据结构之一&#xff0c;用于存储键值对。在 HashMap 中&#xff0c;每个键都映射到一个唯一的值&#xff0c;可以通过键来快速访问对应的值&#xff0c;算法时间复杂度可以达到 O(1)。 HashMap 的实现原理是基于哈希表的&#xff0c;它的底层是…

禁用华为小米?微软中国免费送iPhone15

微软中国将禁用华为和小米手机&#xff0c;要求员工必须使用iPhone。如果还没有iPhone&#xff0c;公司直接免费送你全新的iPhone 15&#xff01; 、 这几天在微软热度最高的话题就是这个免费发iPhone&#xff0c;很多员工&#xff0c;收到公司的通知。因为&#xff0c;登录公司…

ITSS服务经理职责与认可情况分析

随着信息技术的高速发展和广泛应用&#xff0c;企业对信息技术管理和应用的需求日益凸显。 为满足这一迫切需求&#xff0c;对具备专业知识和技能的人才的需求也日益增长&#xff0c;他们负责管理和实施相关项目。 因此&#xff0c;ITSS服务项目经理证书应运而生&#xff0c;这…

提升Selenium在Chrome上的HTML5视频捕获效果的五个方法

在使用Selenium进行网页自动化测试时&#xff0c;捕获HTML5视频是一个常见的需求。然而&#xff0c;许多开发者发现&#xff0c;在使用Chrome浏览器时&#xff0c;视频捕获效果并不理想&#xff0c;经常出现视频背景为空白的问题。本文将概述五种方法&#xff0c;帮助提升Selen…

基于语义的法律问答系统

第一步&#xff0c;准备数据集 第二步&#xff0c;构建索引数据集&#xff0c;问答对数据集&#xff0c;训练数据集&#xff0c;召回评估数据集 第三步&#xff0c;构建dataloader,选择优化器训练模型&#xff0c;之后召回评估 第四步&#xff0c;模型动转静&#xff0c;之后…

eplan软件许可优化解决方案

Eplan软件介绍 Eplan是一款专业的电气设计软件&#xff0c;用于自动化工程和电气系统的设计与文档化。它由德国的Eplan Software & Service GmbH开发&#xff0c;并在全球范围内广泛应用于工程设计和电气工程领域。 Eplan软件提供了全面的工具和功能&#xff0c;以简化和优…

Vue3 引入腾讯地图 包含标注简易操作

1. 引入腾讯地图API JavaScript API | 腾讯位置服务 (qq.com) 首先在官网注册账号 并正确获取并配置key后 找到合适的引入方式 本文不涉及版本操作和附加库 据体引入参数参考如下图 具体以链接中官方参数为准标题 在项目根目录 index.html 中 写入如下代码 <!-- 引入腾…

微软的人工智能语音生成器在测试中达到与人类同等水平

微软公司开发了一种新的神经编解码语言模型 Vall-E&#xff0c;在自然度、语音鲁棒性和说话者相似性方面都超越了以前的成果。它是同类产品中第一个在两个流行基准测试中达到人类同等水平的产品&#xff0c;而且显然非常逼真&#xff0c;以至于微软不打算向公众开放。 VALL-E …

车载测试资料学习和CANoe工具实操车载项目(每日直播)

每日直播时间&#xff1a;&#xff08;直播方式&#xff1a;腾讯会议&#xff09; 周一到周五&#xff1a;20&#xff1a;00-23&#xff1a;00 周六与周日&#xff1a;9&#xff1a;00-17&#xff1a;00 向进腾讯会议学习的&#xff0c;可以关注我并后台留言 直播内容&#xff…

GPMC并口多通道AD采集案例,基于TI AM62x四核处理器平台!

GPMC并口简介 GPMC(General Purpose Memory Controller)是TI处理器特有的通用存储器控制器接口&#xff0c;是AM62x、AM64x、AM437x、AM335x、AM57x等处理器专用于与外部存储器设备的接口&#xff0c;如&#xff1a; (1)FPGA器件 (2)ADC器件 (3)SRAM内存 (4)NOR/NAND闪存 …

electron实现右键菜单保存图片功能

1.创建窗口&#xff0c;加载页面&#xff0c;代码如下&#xff1a; //打开窗口const {ipcMain, BrowserWindow} require("electron") const saveImage require("../ipcMain/saveImage") let win null; ipcMain.handle(on-open-event, (event, args) &g…

Airtest成功案例分享:KLab连续2年携Airtest私有云产品参加CEDEC大会!

一、KLab株式会社介绍 KLab株式会社是一家位于日本的移动游戏开发公司&#xff0c;成立于2000年。公司以开发和运营基于动漫和漫画IP的手机游戏而闻名&#xff0c;尤其是在音乐节奏游戏领域。KLab的一些知名作品包括《LoveLive!学园偶像祭》、《排球少年&#xff1a;新的征程》…

【unity笔记】常见问题收集

一 . Unity Build GI data 卡住问题 问题解决: 参考官方文档&#xff0c;GI(Global Illumination) data 指的是全局照明信息。 在Unity的Edit->Preference中&#xff0c;可以编辑GI缓存路径和分配GI缓存大小。 调出Window->Rendering->Lighting窗口&#xff0c;取消…

阿里云调整全球布局关停澳洲云服务器,澳洲服务器市场如何选择稳定可靠的云服务?

近日&#xff0c;阿里云宣布将关停澳大利亚地域的数据中心服务&#xff0c;这一决定引发了全球云计算行业的广泛关注。作为阿里云的重要海外市场之一&#xff0c;澳洲的数据中心下架对于当地的企业和个人用户来说无疑是一个不小的挑战。那么&#xff0c;在阿里云调整全球布局的…