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

news2024/7/30 10:54:23

下载配置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 过滤条件
-- 所有成绩都及格的学生
-- 没有学生不及格的科目
-- 成绩最低都是80 的学生
SELECT savingID FROM cardInfo GROUP by savingID HAVING MIN(balance) > 50000;

删除新表

drop table tabname

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

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

相关文章

分布式训练

一、分布式计算 跟多GPU不同是&#xff1a;数据不是从主存拿的&#xff0c;是在分布式文件系统拿的&#xff0c;有多个工作站&#xff0c;工作站中有多个GPU&#xff0c;通过网络读取数据到GPU中&#xff0c;GPU通过网络接收到来自参数服务器的参数进行运算计算梯度&#xff0c…

【C++深度探索】全面解析多态性机制(一)

hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#xff1a;大耳朵土土垚的博客 &#x1…

与沃尔玛进行EDI对接,需要了解什么?如何实现EDI对接呢?

与沃尔玛进行EDI对接前&#xff0c;需要了解什么呢&#xff1f; 首先&#xff0c;需要了解什么是EDI&#xff1f; EDI&#xff08;Electronic Data Interchange&#xff09;即电子数据交换&#xff0c;借助EDI使得企业&#xff08;计算机/应用系统&#xff09;与企业&#xff…

腰肌筋膜炎最好的治疗方法

腰部疼痛是腰肌筋膜炎的主要症状&#xff0c;这种疼痛可能是隐痛、酸痛或肿胀痛&#xff0c;且疼痛可能呈持续性或间歇性。在长时间站立、坐姿、弯腰或腰部受寒着凉后&#xff0c;疼痛通常会加重。疼痛可能会扩散到腰部的其他区域&#xff0c;甚至可能影响到臀部或大腿后侧。疼…

基于springboot+mybatis学生管理系统

基于springbootmybatis学生管理系统 简介&#xff1a; 题目虽然是学生管理系统&#xff0c;但功能包含(学生&#xff0c;教师&#xff0c;管理员),项目基于springboot2.1.x实现的管理系统。 编译环境 &#xff1a; jdk 1.8 mysql 5.5 tomcat 7 框架 &#xff1a; springboot…

W外链短网址平台怎么样?抖音/小红书/快手/微信卡片生成

在当今数字化时代&#xff0c;网址的便捷性和易记性对于用户体验和网站推广至关重要。短网址技术应运而生&#xff0c;以其简洁、易记、方便分享的特性&#xff0c;逐渐成为网站优化和推广的重要手段之一。其中&#xff0c;W外链作为一个功能全面的短网址服务平台&#xff0c;以…

mavlink协议解析

1. mavlink数据包格式 字节索引C 版本内容值说明0uint8_t magic数据包启动标记0xFE特定于协议的文本启动 (stx) 标记, 用于指示新数据包的开始。 任何不识别协议版本的系统都将跳过数据包。1uint8_t len载荷长度0 - 255指示以下 payload 部分的长度 (为特定消息固定)。2uint8_t…

一款永久免费的内网穿透工具——巴比达

近期&#xff0c;一款名为巴比达的内网穿透工具凭借其永久免费的特性&#xff0c;以及卓越的性能与安全性&#xff0c;引起了我的关注。本文将深入探讨巴比达如何通过其独创的技术方案&#xff0c;达到企业级数据通信要求。 WanGooe Tunnel协议 首先&#xff0c;巴比达的核心竞…

矩阵管理系统实现后台统一管理的解决方案

在当今数字化浪潮中&#xff0c;企业面临着前所未有的挑战与机遇。如何快速响应市场变化、提升运营效率、降低管理成本&#xff0c;成为众多企业关注的焦点。而矩阵管理系统作为一种新兴的管理工具&#xff0c;凭借其强大的后台统一管理能力&#xff0c;正成为越来越多企业的首…

适合学生写作业的台灯怎么选?一文读懂护眼台灯怎么选!

不知大家发现没有&#xff0c;近些年&#xff0c;戴眼镜的小孩儿是越来越多了&#xff0c;甚至有的地方好多刚上小学一年级的孩子&#xff0c;就已经戴着200度的近视镜了。据统计&#xff0c;如今&#xff0c;中国小学生近视比例为42%&#xff0c;初中生近视比例为80.7%&#x…

技校专业群的生成机制研究

一、引言 随着我国经济的快速发展和产业结构的不断优化&#xff0c;技术型人才的需求日益旺盛。技工学校&#xff08;简称技校&#xff09;作为培养技术型人才的摇篮&#xff0c;其专业群的构建与发展显得尤为重要。专业群作为技校战略发展的核心&#xff0c;不仅能够优化教学…

项目三层架构详情

三层架构 三层架构就是为了符合“高内聚&#xff0c;低耦合”思想&#xff0c;把各个功能模块划分为表示层&#xff08;UI&#xff09;、业务逻辑层&#xff08;BLL&#xff09;和数据访问层&#xff08;DAL&#xff09;三层架构&#xff0c;各层之间采用接口相互访问&#xf…

js ES6 part2

forEach遍历 forEach() 方法用于调用数组的每个元素&#xff0c;并将元素传递给回调函数 主要使用场景&#xff1a; 遍历数组的每个元素 语法 被遍历的数组.forEach(function(当前数组元素&#xff0c;当前元素索引号){ //函数体 }) 1. forEach 主要是遍历数组 2. 参数当前…

7.11 cf div3 A

Problem - A - Codeforces 题目概述 求最少问题数量&#xff0c;以确保能举办m轮比赛&#xff0c;每轮包含一个难度级别为 ‘A’ 到 ‘G’ 的问题。 ac代码 #include<bits/stdc.h> typedef long long ll;#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0) …

算力革命:弹性租赁,解锁无限可能

华为创始人任正非曾在一场程序设计竞赛中说道&#xff0c;我们即将进入第四次工业革命&#xff0c;基础就是大算力。事实上&#xff0c;随着5G、人工智能等信息技术的迅猛发展&#xff0c;算力需求持续增长&#xff0c;但高昂的成本和快速的技术迭代让许多中小企业和个人开发者…

C++20中的指定初始化器(designated initializers)

指定初始化器(designated initializers, 指定初始值设定项)语法如下&#xff1a;C风格指定初始化器语法&#xff0c;初始化数据成员的一种便捷方式 T object { .des1 arg1, .des2 { arg2 } ... }; T object { .des1 arg1, .des2 { arg2 } ... }; 说明&#xff1a; 1.每个指…

libcoap3对接华为云平台

文章目录 前言一、平台注册二、引入源码库1.libcoap仓库编译2.分析网络报文3.案例代码4.编译&运行 总结 前言 通过libcoap3开源代码库对接华为云平台&#xff0c;本文章将讨论加密与不加密的方式对接华为云平台。 一、平台注册 首先&#xff0c;你需要在华为云平台上创建…

【C++课程学习】:new和delete为什么要配套使用,new,delete和malloc,free的比较

&#x1f381;个人主页&#xff1a;我们的五年 &#x1f50d;系列专栏&#xff1a;C课程学习 &#x1f389;欢迎大家点赞&#x1f44d;评论&#x1f4dd;收藏⭐文章 目录 &#x1f3a1;1.new&#xff0c;delete和malloc&#xff0c;free的区别&#xff1a; ⌚️相同点&…

沃尔玛、亚马逊跨境电商测评补单自养号实操指南

通过自养号测评补单来提升流量是一种被众多卖家采用的运营手段&#xff0c;它可以帮助卖家快速提高商品的曝光度和吸引潜在买家。以下是自养号测评的详解&#xff1a; 一、自养号测评的定义 自养号测评是指卖家通过注册并管理自己的海外买家账号&#xff0c;对自家商品进行模…

linux 命令:Debian、ubuntu系统的离线软件包管理工具dkpg详解

目录 一、背景 二、工作原理 1、基本原理 2、与apt工具的对比 2.1优势 2.1.1直接为底层操作&#xff0c;可操控性好 2.1.2安装卸载和配置都可实现 2.2劣势 2.2.1依赖关系处理不足 2.2.2无法从软件仓库获取软件包 2.2.3用户界面不友好 2.3 总结 三、语法和使用 1、…