MySQL、创建数据库、表、SQL 函数:数学函数、字符串函数、日期函数、聚合函数
DAY18.1 Java核心基础
MySQL
创建数据库
数据库是一个服务,实际开发需要根据具体的项目创建对应的数据库实例
create database mytest1 default character set utf8 collate utf8_general_ci;
create database mytest2 default character set utf8 collate utf8_bin;
collate 设置数据库的校验字符集:如何给数据库中的数据进行排序,不在 SQL 中添加任何排序语句的情况下,默认的排序值
utf8_general_ci:不区分大小写
utf8_bin:区分大小写
现在将a和B插入到两个数据库的users表中,两个表中的字段都是a和B,现在我们来查询试试
use mytest1;
insert into users(name) VALUES('a');
insert into users(name) VALUES('B');

mytest1:a B
mytest2:B a
use mytest1;
SELECT * FROM users ORDER BY name;
mytest1结果:

mytest1 校验字符集不区分大小写,所以 B 排在 a 后面
use mytest2;
SELECT * FROM users ORDER BY name;
mytest2结果:

mytest2 校验字符集区分大小写,所以比较的是字母的二进制编码,
二进制编码中
B:66
a:97
默认是升序排列,所以越小的排在前面,所以 B a
创建数据表
create table 表名(字段列表);
-- 示例:
create table users(name varchar(20)
);
MySQL 中的数据类型
整数类型:tinyint(1 个字节 byte)smallint(2 个字节)mediumint(3 个字节)int(4 个字节)bigint(8 个字节)
浮点类型:float(4 个字节)double(8 个字节)
定点类型:decimal(M,D) M 数字的最大值(精度)D 小数点后数字的长度(标度)
日期和时间类型:datetime、date、timestamp、time、year
- year:1 个字节,取值范围:1901~2155
- time:3 个字节,取值范围:-838:59:59 ~ 838:59:59 负数是因为它可以表示时间间隔
- date:3 个字节,取值范围:1000-01-01 ~ 9999-12-31
- datetime:8 个字节,取值范围:1000-01-01 00:00:00 ~ 9999-12-31 23:59:59
- timestamp:4 个字节,表示 1970 年 1 月 1 号到现在的毫秒数
- 字符串类型:char(M) M 个字节、varchar(M) M+1 个字节、text(M) M + 2 个字节
- 二进制类型:bit、binary、varbinary、tinyblob、blob、mediumblob、longblob
- bit(M) M 个字节
- binary(M) M 个字节
- varbinary(M) M 个字节
- tinyblob 255 个字节
- blob 2^16-1 个字节
- mediumblob 2^24-1 个字节
- longblob 2^32-1 个字节
创建数据库
1、创建数据库
create database 数据库名 default character set utf8 collate utf8_general_ci;
2、删除数据库
drop database 数据库名;
3、查看数据库
show databases;
4、选择数据库(在需要操作数据的时候选择一个数据库操作,不然不知道你要操作哪一个数据库)
use 数据库名;
5、创建数据表
create table 数据表名(字段列表);
-- 示例:
create table users(name varchar(20)
);
6、删除数据表
drop table 数据表名;
7、查看数据表
show tables;
8、查看表结构
desc 数据表名;
9、修改表结构
-
新增一个字段
-- 在student表中新增一个字段sex varchar(2)类型 alter table student add sex varchar(2); -
修改一个字段
-- 修改student表中的sex字段,改为字段名为gender int类型 alter table student change sex gender int; -
删除一个字段
-- 删除student表中的gender字段 alter table student drop gender;
SQL 函数
SQL 提供了很多函数,可以完成很复杂的功能
业务尽可能使用 Java 来完成,SQL 一般只负责对数据的管理
MySQL 本身是一种检索机制,消耗很多资源
SQL 只是针对查询出来的结果进行了处理,而不会影响到原数据的值
数学函数
abs() 求绝对值
select abs(score) from student;

返回结果

floor() 返回小于参数的最大整数(分数是90.1,返回的是90)
select floor(score) from student;
ceil() 返回大于参数的最小整数(分数是90.1,返回的是91)
select ceil(score) from student;
字符串函数
insert(s1,index,len,s2)
s1 中 index 位置开始,长度为 len 的字符替换成 s2,index 从 1 开始
select insert(name,1,2,"小红") from student;
upper()、ucase() 将字母变为大写
select ucase(name) from student;
select upper(name) from student;
lower()、lcase() 将字母变为小写
select lower(name) from student;
select lcase(name) from student;
left(s,len) 返回 s 字符串的前 len 个字符
select left(name,1) from student;
right(s,len) 返回 s 字符串的后 len 个字符
select right(name,2) from student;
substring(s,index,len) 截取 s 字符串,从 index 位置开始,长度为 len
select substring(name,2,1) from student;
reverse() 反序输出
select reverse(name) from student;
日期函数
curdate() current_date() 获取当前日期
select current_date();
curtime() current_time() 获取当前时间
select current_time() from student;
now() 获取当前日期+时间
select now();
datediff(d1,d2) d1 和 d2 之间相隔的天数
select datediff("2024-05-01","2021-06-23");
adddate(d,n) 返回 d 日期之后 n 天的日期
select adddate("2024-05-01",1000);
subdate(d,n) 返回 d 日期之前 n 天的日期
select subdate("2024-05-01",1000);
聚合函数
count() 根据某个字段统计数量
select count(id) from student;
sum() 计算某个字段值的总和
select sum(score) from student;
avg() 求某个字段值的平均值
select avg(score) from student;
max() 求某个字段的最大值
select max(score) from student;
min() 求某个字段的最小值
select min(score) from student;
相关文章:
MySQL、创建数据库、表、SQL 函数:数学函数、字符串函数、日期函数、聚合函数
DAY18.1 Java核心基础 MySQL 创建数据库 数据库是一个服务,实际开发需要根据具体的项目创建对应的数据库实例 create database mytest1 default character set utf8 collate utf8_general_ci; create database mytest2 default character set utf8 collate utf8…...
关于我对接了deepseek之后部署到本地将数据存储到mysql的过程
写在前面 今天写一下使用nodejs作为服务端,vue作为客户端,mysql的数据库,对接deepseek的全过程,要实现一个很简单的效果就是,可以自由的询问,然后可以将询问的过程存储到mysql的数据库中。 文档对接 deeps…...
23种设计模式-策略(Strategy)设计模式
策略设计模式 🚩什么是策略设计模式?🚩策略设计模式的特点🚩策略设计模式的结构🚩策略设计模式的优缺点🚩策略设计模式的Java实现🚩代码总结🚩总结 🚩什么是策略设计模式…...
【Exception】MybatisPlusException: can not find lambda cache for this entity
文章目录 环境 | Environment复现步骤 | Reproduction steps报错日志 | Error log源码 | Source CodeUserServiceImpl.javaAddressServiceImpl.javaAbstractSubTableBaseServiceImpl.javaUserEntity.javaAddressEntity.javaSubTableBaseEntity.java 原因分析 | Analysis解决方案…...
vue ts+Windi CSS
1、创建vue项目 trae(字节)打开一个空文件夹 npm install -g vue/cli vue create my-project cd my-project vue add typescript npm run serve vue项目创建完成 2、安装windicss vue add windicss vue.config.js配置 npm install vue-router …...
ffmpeg系列(三)—— 音频重采样
SwrContext 一、SwrContext 的重要字段 SwrContext 是音频重采样的核心配置对象,其关键字段决定了重采样的行为和性能。以下是常用字段及其作用: 字段名称类型作用典型值示例in_sample_rateint输入音频的采样率(Hz)。44100out_…...
Android Gradle 插件(AGP)版本与 Gradle 版本需要严格对应
一、AGP 与 Gradle 版本对照表 Android Gradle 插件版本对应 Gradle 版本适用 Android Studio 版本8.1.x8.2Arctic Fox (2020.3.1+)8.0.x8.0Arctic Fox (2020.3.1+)7.4.x7.5.1IntelliJ IDEA 2022+7.3.x7.4IntelliJ IDEA 2022+7.2.x7.3.3IntelliJ IDEA 2021.3+7.1.x…...
Angular由一个bug说起之十五:自定义基于Overlay的Tooltip
背景 工具提示(tooltip)是一个常见的 UI 组件,用于在用户与页面元素交互时提供额外的信息。由于angular/material/tooltip的matTooltip只能显示纯文本,所以我们可以通过自定义Directive来实现一个灵活且功能丰富的tooltip Overlay…...
使用 Chromedp 监听网页请求和响应
使用 Chromedp 监听网页请求和响应 在进行网络爬虫的时候,有很多网站都有反爬机制,比如你想抓点数据,结果发现每次请求都带一堆奇奇怪怪的参数 —— 什么 timestamp 签名、AES 加密的字段,还有各种 Token 令牌,跟密码…...
Java中用Stream流取出分组后每组最大值对象的ID
取出分组后每组最大值对象的ID 如果只需要获取这些对象的ID(或其他特定字段),而不是整个对象,可以采用以下方法: 方法1:先获取对象再提取ID List<String> customerIds orders.stream().collect(Coll…...
GPT-SoVITS本地部署:低成本实现语音克隆远程生成音频全流程实战
文章目录 前言1.GPT-SoVITS V2下载2.本地运行GPT-SoVITS V23.简单使用演示4.安装内网穿透工具4.1 创建远程连接公网地址 5. 固定远程访问公网地址 前言 今天要给大家安利一个绝对能让你大呼过瘾的声音黑科技——GPT-SoVITS!这款由花儿不哭大佬精心打造的语音克隆神…...
使用HTTP提交git时,每次都要输入用户名和密码的解决方案
通过https提交的git项目,每次提交都需要输入用户名和密码 解决方案如下: 打开项目目录,通过终端输入: git config --global credential.helper store验证方式: 重启 scode修改or添加文件后使用git上传, 本次需要帐号密码再次修改or添加文件…...
Flutter视频播放优化
在Flutter中实现流畅视频播放,选择合适的播放器插件是关键。推荐使用以下两类插件: 跨平台低延迟方案 flutter_vlc_player:基于VLC引擎,支持RTSP/RTMP协议,通过hwAcc: HwAcc.full启用硬件加速,配合setOpti…...
嵌入式学习第二十八天--顺序栈
栈的基本代码 栈是限定仅在表尾进行插入和删除操作的线性表。 先进后出、后进先出 栈顶:允许操作的一端 栈底:不允许操作的一端 入栈,出栈。 顺序栈 链式栈 302\5 1.创建 CreateSeqStack 2.销毁 DestroySeqStack 3.判断是否为空栈 IsEmptySeqStack 4.判断是否为满…...
基于MCP协议的多模态模型优化在医疗3D打印精密人工关节制造中的研究
一、引言 1.1 研究背景与意义 在全球人口老龄化趋势愈发明显的当下,诸如骨关节炎、类风湿性关节炎这类关节疾病的发病率不断攀升,进而使得人工关节置换手术的需求呈现出激增态势。人工关节置换手术作为治疗终末期关节疾病的有效手段,能够显著缓解患者疼痛,提升关节功能与生…...
【Unity】 HTFramework框架(六十三)SerializableDictionary可序列化字典
更新日期:2025年3月26日。 Github 仓库:https://github.com/SaiTingHu/HTFramework Gitee 仓库:https://gitee.com/SaiTingHu/HTFramework 索引 一、SerializableDictionary可序列化字典1.使用SerializableDictionary2.实现思路 二、Serializ…...
MATLAB绘图配色包说明
本栏目将分享MATLAB数据分析图表,该贴讲述配色包的使用 将配色包colormap_nclCM文件夹添加到路径close all(尽量不要删),使用map colormap(nclCM(309))时会多出来一张空白图片。配色资源来自slandarer;找不到合适颜色…...
8路CXP相机采集系统介绍
8xCXP相机采集系统介绍 目录 1 系统概述 4 2 硬件架构 5 2.1 FPGA处理单元 5 2.2 CXP接口层 6 2.3 CXP相机说明与使用要求 7 2.4 SSI控制器板 8 3 FPGA方案 9 3.1 FPGA实现 9 3.2 Block Design说明 10 4 软件方案 14 4.1 嵌入式层 14 4.2 上位机软件(C…...
Stable Diffusion 基础模型结构超级详解!
1. Transformer 第一个只用 Attention 机制来解决序列到序列问题的模型,最早被 Google 用来解决翻译问题 对于中英翻译而言,需要解决三个具体的问题: 如何用数字表示中文和英文 如何让神经网络理解语义 如何让神经网络生成英文 1.1 Tok…...
【Linux网络(七)】数据链路层
目录 1、认识MAC地址 2、 mac帧格式 3、局域网的通信原理 4、ARP协议 浏览器输入url1后发生的事情:(面试题) 数据链路层解决的是:直接相连的主机(不仅仅包括电脑,还包括路由器)之间&#x…...
Nginx RTMP 处理模块 (ngx_rtmp_handler.c) 详细分析
ngx_rtmp_handler 是 Nginx RTMP 模块中的核心处理部分,主要负责处理 RTMP 流会话中的数据接收、发送、ping 操作以及分块大小的设置等。 1. 全局变量 ngx_rtmp_naccepted: 记录接受的 RTMP 连接数。 ngx_rtmp_bw_out 和 ngx_rtmp_bw_in: 分别表示输出带宽和输入带…...
2025年渗透测试面试题总结-某奇安信-Ateam(题目+回答)
网络安全领域各种资源,学习文档,以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具,欢迎关注。 目录 奇安信-Ateam 一、SQL注入攻防技术体系 1.1 SQL注入类型矩阵(基于利用方式) …...
前端工程化--gulp的使用
gulp 介绍 gulp 是一个基于 Nodejs 的自动化构建工具,中文主页能自动化地完成 javascript/coffee/sass/less/html/image/css 等文件的合并、压缩、检查、监听文件变化、浏览器自动刷新、测试等任务 使用步骤: 安装 nodejs 全局安装 gulp npm install…...
谈谈对spring IOC的理解,原理和实现
一、IoC 核心概念 1. 控制反转(Inversion of Control) 传统编程中对象自行管理依赖(主动创建),而IoC将控制权转移给容器,由容器负责对象的创建、装配和管理,实现依赖关系的反向控制。 2. 依赖…...
Windows 10 ARM64平台MFC串口程序开发
Windows 10 IoT ARM64平台除了支持新的UWP框架,也兼容支持老框架MFC。使得用户在Windows 10 IoT下可以对原MFC工程进行功能升级,不用在新框架下重写整个工程。熟悉MFC开发的工程师也可以在Windows 10 IoT平台下继续使用MFC进行开发。 本文展示MFC串口程序…...
31天Python入门——第16天:模块与库详解
你好,我是安然无虞。 文章目录 Python模块模块之间的调用 Python包库的概念Python标准库安装第三方库 \_\_name\_\_ \_\_main\_\_ Python模块 在 Python 中, 模块是一个包含函数、变量和类等代码定义的py文件. 所以也可以说, 普通的py文件就是一个模块. 模块可以…...
设计模式(创建型)- 原型模式
目录 定义 类图 角色 优缺点 优点 缺点 应用场景 案例展示 浅克隆 深克隆 定义 原型模式旨在创建重复的对象,同时确保良好的性能表现。它通过复制现有对象(原型)来创建新对象,而非使用传统的构造函数创建方式。这种设计…...
Redis + Caffeine多级缓存电商场景深度解析
Redis Caffeine多级缓存 Redis Caffeine多级缓存电商场景深度解析一、实施目的二、具体实施2.1 架构设计2.2 组件配置2.3 核心代码实现 三、实施效果3.1 性能指标对比3.2 业务指标改善3.3 系统稳定性 四、关键策略4.1 缓存预热4.2 一致性保障4.3 监控配置Prometheus监控指标 …...
spring-ai ollama小试牛刀
序 本文主要展示下spring-ai ollama的使用 示例 pom.xml <dependency><groupId>org.springframework.ai</groupId><artifactId>spring-ai-ollama-spring-boot-starter</artifactId></dependency>这里以ollama示例 配置 spring:ai:olla…...
在 CentOS 系统中开机自动执行 Shell 脚本
在 CentOS 系统中,可以通过以下方法设置开机自动执行 Shell 脚本。推荐使用 systemd 服务(现代 Linux 系统的标准方式),也可以使用传统的 /etc/rc.local 方法。 方法 1:使用 Systemd 服务(推荐)…...
