学习测试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);-- 4)查询不同的存款类型的银行卡余额最大值大于500的银行卡卡号和余额
select cardID,balance from cardInfo  where savingid in (select  savingid  from cardInfo GROUP BY savingid having max(balance)>500);

连表 左连接 右连接

左连接称之为左外连接 右连接称之为右外连接 这俩个连接都是属于"外连接"
左连接关键字:left join 表名 on 条件 / left outer 表名 join on 条件
右连接关键字:right join 表名 on 条件/ right outer 表名 join on 条件

左连接说明:left join 是left outer join的简写,左(外)连接,左表(a_table)的记录将会全部表示出来, 而右表(b_table)只会显示符合搜索条件的记录。右表记录不足的地方均为NULL
右连接说明:right join是right outer join的简写,与左(外)连接相反,右(外)连接,左表(a_table)只会显示符合搜索条件的记录,而右表(b_table)的记录将会全部表示出来。左表记录不足的地方均为NULL。

下方为左连接的表现
在这里插入图片描述

SELECT * FROM cardInfo left join tradeInfo on  cardInfo.cardID = tradeInfo.cardID ;

练习

-- 3)查询交易总额超过10000的月份 SELECT month(transDate)  FROM tradeInfo group by  month (transDate) having SUM(transMoney) > 10000;-- 2)查询手机号是135开头的客户号和银行卡余额
SELECT cardInfo.customerID,cardInfo.balance FROM cardInfo WHERE cardInfo.customerID IN (SELECT customerID FROM userInfo WHERE userInfo.telephone LIKE '135%');-- 1)查询存入和支取的总额分别是多少
SELECT transType,SUM(tradeInfo.transMoney) FROM tradeInfo GROUP by tradeInfo.transType;

增加字段

insert into 表名 values (值1,值2,值3··) 除了自增,其他的必须所有字段名全都输入
insert into 表名(列名,列名2,列名3··) values (值1,值2,值3··) 字段名对应值,一一对应

INSERT INTO userInfo VALUES(6,"王佳",675365343497420574,16543268749,"湖北荆门");
-- Column count doesn’t match value count at row 1 意思是列数目跟值数目不匹配。

修改表

-- UPDATE userInfo SET customerName = '新值' WHERE customerName = '旧值'
UPDATE userInfo SET customerName = '王天' WHERE customerName = '王佳'

删除表

-- 删除整张表
drop table tabname--DELETE FROM 表名 WHERE 筛选条件 (列名 = '值')
DELETE FROM userInfo WHERE customerName = '乔天真'

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

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

相关文章

Typescript 模块小知识-global scope

问题表现 在编写ts代码的时候遇到一个问题, 表现为, 如果在某个ts工程中, 如果多个文件里面没有任何导出export或者是export default, 那么这些文件如果有const或者是let定义相同的声明都会报错如下 无法重新声明块范围变量 a/a.ts 和 index.ts 和 index2.ts 都没有进行expor…

基于Redisson 实现 Redis 分布式锁

代码示例&#xff1a; GetMapping("/testJmeter")public void testJmeter() {synchronized (this){int stock Integer.parseInt(stringRedisTemplate.opsForValue().get("stock"))if (stock > 0) {int realStock stock - 1;stringRedisTemplate.opsFo…

盘点:流媒体视频流协议与EasyCVR视频监控技术的深度融合

随着科技的不断进步&#xff0c;视频监控技术已经渗透到了社会的各个角落&#xff0c;从公共安全到企业运营&#xff0c;再到家庭安全&#xff0c;其应用范围日益广泛。而视频流格式作为视频监控技术的核心要素之一&#xff0c;其选择和应用对于确保视频传输的流畅性、清晰度和…

Python爬虫教程第3篇-解决使用reqeusts遇到的ProxyError异常

起因 问题出现在windows电脑上&#xff0c;我用mac执行程序的时候并不会报错&#xff0c;但是如果在windows上的时候&#xff0c;大部分windows电脑会报错&#xff0c;而有些版本低的windows电脑又不会报错。 异常栈信息 HTTPSConnectionPool, Cannot connect to proxy, no …

基于SpringBoot的校园疫情防控系统

你好&#xff0c;我是专注于计算机科学与技术的研究者。如果你对我的工作感兴趣或有任何问题&#xff0c;欢迎随时联系我。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringBoot框架&#xff0c;B/S架构 工具&#xff1a;Eclipse&#xff0c;Mav…

2024中国互联网大会 | 中国电信携手产业链伙伴推动低空经济行业创新与发展

低空经济是指以民用有人驾驶和无人驾驶航空器在低空空域内的各类飞行活动为牵引&#xff0c;辐射带动相关领域融合发展的综合经济形态。2024年全国两会&#xff0c;“低空经济”首次写入国务院政府工作报告。 赛迪顾问在《中国低空经济发展研究报告&#xff08;2024&#xff09…

python作业二

# 二进制转化为十进制 num input("num:")def binaryToDecimal(binaryString):he 0length len(binaryString)for i in range(length):he int(binaryString[i]) * 2 ** (length - i - 1)return heprint(binaryToDecimal(num))代码运行如下&#xff1a; import math…

特种设备管理为什么这么难?为何它是安全生产的重中之重?

随着工业化进程的加速和科技水平的不断提升&#xff0c;特种设备作为工业生产、公共服务和基础设施建设中的关键要素&#xff0c;其应用范围日益广泛&#xff0c;从大型压力容器、锅炉、电梯、叉车到压力管道、客运索道等&#xff0c;无一不渗透于我们日常生活的方方面面。然而…

【qt】QTcpSocket相关的信号

QTcpSocket可以在这里找到相关的信号 进行信号槽的关联 connect():这个信号在connectToHost()被调用并且连接已经成功建立之后发出 disconnected():该信号在套接字断开连接时发出 stateChanged(QAbstractSocket::SocketState socketState):每当QAbstractSocket的状态发生变化…

【若依前后端分离】通过输入用户编号自动带出部门名称(部门树)

一、部门树 使用 <treeselect v-model"form.deptId" :options"deptOptions" :show-count"true" placeholder"请选择归属部门"/> <el-col :span"12"><el-form-item label"归属部门" prop"dept…

音视频开发—使用FFmpeg从纯H264码流中提取图片 C语言实现

文章目录 1.H264码流文件解码流程关键流程详细解码流程详细步骤解析 2.JPEG编码流程详细编码流程详细步骤解析 3.完整示例代码4.效果展示 从纯H.264码流中提取图片的过程包括解码和JPEG编码两个主要步骤&#xff0c;以下是详细阐述 1.H264码流文件解码流程 关键流程 查找编解…

敏捷开发笔记(第10章节)--Liskov原则(LSP)

目录 1&#xff1a;PDF上传链接 10.1 Liskov替换原则&#xff08;LSP&#xff09; 10.2 一个违反LSP的简单例子 10.6 启发式规则和习惯用法 10.7 结论 1&#xff1a;PDF上传链接 【免费】敏捷软件开发(原则模式与实践)资源-CSDN文库 OCP背后的主要机制是抽象(abstraction…

group 与查询字段

需求 每周周一&#xff0c;统计菜单在过去一周&#xff0c;点击次数&#xff0c;和点击人数&#xff08;同一个人访问多次按一次计算&#xff09; 表及数据 日志表 CREATE TABLE t_data_log ( id varchar(50) NOT NULL COMMENT 主键id, operation_object varchar(500) DE…

【D3.js in Action 3 精译】1.3 D3 视角下的数据可视化最佳实践(下)

当前内容所在位置 第一部分 D3.js 基础知识 第一章 D3.js 简介 ✔️ 1.1 何为 D3.js&#xff1f;1.2 D3 生态系统——入门须知 1.2.1 HTML 与 DOM1.2.2 SVG - 可缩放矢量图形1.2.3 Canvas 与 WebGL1.2.4 CSS1.2.5 JavaScript1.2.6 Node 与 JavaScript 框架1.2.7 Observable 记事…

我的世界1.21多种服务端开服教程,原版/Forge/Fabric/Paper/Mohist...,Minecraft开服教程

Minecraft&#xff08;MC&#xff09;1.21版多种服务端开服教程&#xff0c;我的世界1.21服务器搭建教程&#xff0c;MC原版/Forge/Fabric/Paper/Mohist服务端搭建教程&#xff0c;我的世界MOD/插件服开服教程。 本教程使用 Linux系统MCSManager 面板来搭建Minecraft服务器。 …

人工智能行业应用-垃圾识别一

垃圾识别应用主要体现在AI图像垃圾识别技术上&#xff0c;这是一种基于人工智能和计算机视觉技术的图像处理技术&#xff0c;广泛应用于各个领域以提高垃圾处理的效率和准确性。 1、垃圾识别效果图 2 垃圾识别任务分析 综合利用Python语言、Qt开发模块&#xff0c;OpenCV开发模…

数据结构(Java):单链表面试OJ题

1、题一&#xff1a;获取链表倒数第k个节点 . - 力扣&#xff08;LeetCode&#xff09; 1.1 思路解析 此题我们使用双指针法求解。 首先&#xff0c;我们要知道&#xff0c;倒数的第k个节点&#xff0c;距离倒数第一个节点还需要移动k-1次。 1.那么我们可以定义出两个指针&a…

SQL去重的四种方法

去重是指&#xff1a;查询的时候, 不显示重复&#xff0c;并不是删除表中的重复项 数据表&#xff1a; 方法1&#xff1a;distinct去重 作用&#xff1a;只能一列去重&#xff0c;当distinct后跟大于1个参数时&#xff0c;他们之间的关系是&&(逻辑与)关系&#xff0c;…

00 Debian字符界面如何支持中文

作者&#xff1a;网络傅老师 特别提示&#xff1a;未经作者允许&#xff0c;不得转载任何内容。违者必究&#xff01; Debian字符界面如何支持中文 《傅老师Debian知识库系列之00》——原创 前言 傅老师Debian知识库特点&#xff1a; 1、拆解Debian实用技能&#xff1b; 2、…

ArcGIS获取21天免费教程,不用自己的邮箱

因为迟迟等不到3.1学习版本&#xff0c;但又很眼馋3.1的功能。 在群友的提醒下&#xff0c;官网免费注册21天试用&#xff0c;注册一次可以用21天&#xff0c;基本全部功能都可以使用。 &#xff08;也有群里的人用PayPal支付&#xff0c;然后设置离线许可&#xff0c;官网退…