mysql8安装基础操作(一)
一、下载mysql8.0
1.查看系统glibc版本
这里可以看到glibc版本为2.17,所以下载mysql8.0的版本时候尽量和glibc版本对应
[root@node2 ~]# rpm -qa |grep -w glibc
glibc-2.17-222.el7.x86_64
glibc-devel-2.17-222.el7.x86_64
glibc-common-2.17-222.el7.x86_64
glibc-headers-2.17-222.el7.x86_64
2.下载包
官网地址
https://downloads.mysql.com/archives/community/
如下图:

具体下载地址如下:
wget https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.36-linux-glibc2.17-x86_64.tar.xz
3.安装
[root@node2 ~]# tar xf mysql-8.0.36-linux-glibc2.17-x86_64.tar.xz
[root@node2 ~]# mv mysql-8.0.36-linux-glibc2.17-x86_64 /usr/local/mysql8创建数据目录
[root@node2 ~]# mkdir -p /data/mysql/data
[root@node2 ~]# mkdir -p /data/mysql/tmp创建用户、修改文件权限
[root@node2 ~]# useradd mysql
[root@node2 ~]# chown -R mysql:mysql /usr/local/mysql8
[root@node2 ~]# chown -R mysql:mysql /data/mysql
4.配置my.cnf
这里是最简单的配置,能够启动即可
vim /etc/my.cnf
[client]
port = 3306
socket = /data/mysql/tmp/mysql.sock[mysql]
no-auto-rehash[mysqld]
user = mysql
port = 3306
basedir = /usr/local/mysql8
datadir = /data/mysql/data
socket = /data/mysql/tmp/mysql.sock
mysqlx_socket = /data/mysql/tmp/mysqlx.sock
pid-file = /data/mysql/tmp/mysql.pid
character-set-server = utf8mb4
skip_name_resolve = 1
5.初始化数据库
cd /usr/local/mysql8/bin/
./mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql8/ --datadir=/data/mysql/data/
6.启动数据库
cp /usr/local/mysql8/support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
/etc/init.d/mysqld start重启命令如下
service mysqld restart
7.开机启动
# 这样操作能成功,是因为启动脚本中有chkconfig的配置
chkconfig --add mysqld
二、database基本操作
1.mysql中的注释
在mysql中注释使用 #
2.查看所有数据库
mysql> show databases;
3.切换数据库
mysql> use sys;
Database changed
4.查看所有表
mysql> show tables;
5.创建数据库
mysql> create database mydb;
Query OK, 1 row affected (0.01 sec)
6.删除数据库
mysql> drop database mydb;
Query OK, 0 rows affected (0.01 sec)
三、表的基本操作
1.数据类型
只写一些常见的数据类型
| 数据类型 | 大小 | 用途 |
|---|---|---|
| int | 4 bytes(4个字节) | 普通大小整数 |
| bigint | 8 bytes(8个字节) | 大整数 |
| char | 0-255 bytes | 定长字符串 |
| varchar | 0-65535 bytes | 变长字符串 |
| date | YY-MM-DD | 日期 |
| datetime | YY-MM-DD HH:MM:SS | 日期和时间 |
| timestamp | 时间戳 |
2.创建表
语法格式:
其中[] 中的内容可以写,也可以不写。
但是要注意:varchar类型的宽度必须指定
create table 表名(字段名1 类型[(宽度)] [约束条件] [comment '字段说明'],字段名2 类型[(宽度)] [约束条件] [comment '字段说明'],字段名3 类型[(宽度)] [约束条件] [comment '字段说明'],
)[表的一些设置参数]
例子:
mysql> create table student(id int,name varchar(20),age int,gender varchar(20),birthday date);
3.表结构相关操作
3.1 查看表的创建语句
mysql> show create table student;
3.2 查看表结构
mysql> desc student;
3.3 删除表
mysql> drop table student;
Query OK, 0 rows affected (0.01 sec)
3.4 添加字段
语法:
alter table 表名 add 列名 类型(长度) [约束];
例子:为student表添加about字段
mysql> alter table student add about varchar(20);
3.5 修改字段名
语法
alter table 表名 change 旧列名 新列名 类型(长度) [约束];
实例: 将about字段名改为news
alter table student change about news varchar(20);
3.6 删除列
语法:
alter table 表名 drop 列名;
例子:删除news字段
mysql>
mysql> alter table student drop news;
3.7 修改表名
语法:
rename table 原表名 to 新表名;
例子: 将student表改为stu;
mysql> rename table student to stu;
4.insert语句
4.1 语法
语法1:根据字段名插入数据
insert into 表(字段名1,字段名2,字段名3......) values(值1,值2,值3......);
语法2:向所有列插入数据
insert into 表 values(值1,值2,值3......);
4.2 插入实例
全部插入为空值
insert into student values();
插入具体值
mysql> insert into student values(1,'zhangsan',20,'boy','2020-01-01');
5.update语句
语法:
修改所有的列
update 表名 set 字段名=值,字段名=值,......;修改满足条件的列
update 表名 set 字段名=值,字段名=值 where 条件;
实例:
update student set age=21 where name='zhangsan';
6.delete语句
语法:
删除表内所有内容
delete from 表;删除表内指定的内容
delete from 表 whete 条件;
6.1 实例:
delete from student;delete from student where name='zhangsan';
6.2 删除值为NULL的行
delete from student where id is NULL;
四、mysql约束
1.概念
约束的概念是出现在创建表的时候,会给字段创建对应的约束条件。约束的作用就是 “限制表中数据” 的条件
2.分类
| 条件 | 语法 |
|---|---|
| 主键约束 | primary key(比较重要) |
| 自增长约束 | auto_increment(比较重要) |
| 非空约束 | not null |
| 唯一性约束 | unique |
| 默认约束 | default |
| 零填充约束 | zerofill |
| 外键约束 | foreign key |
3.主键约束
3.1 概念
主键约束相当于 唯一约束 + 非空约束的组合。主键约束不允许重复,不允许出现空值
每个表最多只允许一个主键
当创建主键约束时,系统默认会在所在的列和列组合上建立对应的唯一索引
主键主要是为了标识一行的数据的唯一性
3.2 添加单列主键
在创建表的时候添加主键
create table teacher(# 这里给id字段设置了主键id int primary key,name char);
3.3 添加多列主键
多列主键 也叫做(联合主键)
语法:
create table 表 (字段1 类型 约束条件,......primary key(字段1,字段2))
3.4 alter 添加主键
如果表创建完毕了忘记了添加了主键,然后需要用alter添加
语法:
alter table 表名 add primary key(字段名);
例子:
alter table teacher add primary key(id);
3.5 删除主键
alter table 表名 drop primary key;
4.自增长约束
当主键定义为自增长后,这个主键的值就不需要用户输入数据了,而由数据库系统根据定义自动赋值
一张表只能有一列使用自增长约束
自增长字段的类型必须是整数类型
自增长的最大值受该字段数据类型的最大值限制,如果达到上线,会自动失效.
语法:在字段后边加上auto_increment
create table 表 (字段1 类型 auto_increment,字段2 类型 约束条件,
)
例子:
一般主键约束和自增长一起出现。
create table teacher(id int primary key auto_increment,name varchar(20)
);
插入数据
insert into teacher values(NULL,'zhangsan');
insert into teacher values(NULL,'lisi');
insert into teacher values(NULL,'wangwu');
结果如下:
mysql> select * from teacher;
+----+----------+
| id | name |
+----+----------+
| 1 | zhangsan |
| 2 | lisi |
| 3 | wangwu |
+----+----------+
5.非空约束
create table teacher(id int, name char not null
);
#插入数据报错
mysql> insert into teacher values(1,NULL);
ERROR 1048 (23000): Column 'name' cannot be null
5.1 现有字段添加not null
alter table 表 modify 字段 类型 not null;
6.唯一约束
语法:创建表时添加
create table teacher(id int, name char unique
);
创建完后的表
alter table teacher add unique(id);
7.默认约束
默认约束是用来指定某列的默认值
语法:
create table teacher(name varchar(20),age int default 20
);
insert into teacher (name) values('zhangsan');mysql> select * from teacher;
+----------+------+
| name | age |
+----------+------+
| zhangsan | 20 |
+----------+------+
注意:这里不能插入NULL,不然默认值不生效。
相关文章:
mysql8安装基础操作(一)
一、下载mysql8.0 1.查看系统glibc版本 这里可以看到glibc版本为2.17,所以下载mysql8.0的版本时候尽量和glibc版本对应 [rootnode2 ~]# rpm -qa |grep -w glibc glibc-2.17-222.el7.x86_64 glibc-devel-2.17-222.el7.x86_64 glibc-common-2.17-222.el7.x86_64 gl…...
MIT6.5830 实验0
前置 本次实验使用 Golang 语言实现,在之前的年份中,都是像 cs186 那样使用 Java 实现。原因: Golang 语言作为现代化语言,简单易上手但功能强大。 使参加实验的同学有同一起跑线,而不是像Java那样,有些同…...
【简便方法和积累】pytest 单元测试框架中便捷安装插件和执行问题
又来进步一点点~~~ 背景:之前写了两篇关于pytest单元测试框架的文章,本篇内容对之前的做一个补充 一、pytest插件: pytest 有非常多的插件,很方便,以下为插件举例: pytest,pytest-html&#x…...
Zabbix数据库分离与邮件报警
基础环境:要有zabbix服务端与被监控端实验目标:源数据库与服务端存放在一台服务器上,分离后源数据库单独在一台服务器上,zabbix服务端上不再有数据库。环境拓扑图: 实验步骤: 1.在8.7服务器上安装相同版本…...
mybatisplus-多数据源配置
1. 流程 pom文件yml配置多数据源具体服务添加注解DS(“***”) 1.pom文件 <!--mybatis plus 起步依赖--><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.0</vers…...
微信小程序(二十八)网络请求数据进行列表渲染
注释很详细,直接上代码 上一篇 新增内容: 1.GET请求的规范 2.数据赋值的方法 源码: index.wxml <!-- 列表渲染基础写法,不明白的看上一篇 --> <view class"students"><view class"item">&…...
ubuntu22.04 安装conda
要在Ubuntu 22.04上安装Anaconda,可以遵循以下步骤: 首先,打开终端并更新系统包仓库,也需要安装curl工具,这可以通过以下命令完成: sudo apt update && sudo apt install curl -y使用curl命令行工具…...
W801学习笔记十:HLK-W801制作学习机/NES游戏机(总结)
本章总结一下整个开发过程中遇到的问题: 1、引脚的抗干扰问题: 屏幕显示的时候,概率出现花屏。无论怎么修改代码都不能解决,一个偶然的机会,发现当手触摸屏幕的WR和CS引脚时,屏幕会正常。查阅资料&#x…...
《HTML 简易速速上手小册》第6章:HTML 语义与结构(2024 最新版)
文章目录 6.1 语义化标签的重要性6.1.1 基础知识6.1.2 案例 1:使用 <article>, <section>, <aside>, <header>, 和 <footer>6.1.3 案例 2:构建带有嵌套语义化标签的新闻网站6.1.4 案例 3:创建一个带有 <mai…...
分析HarmonyOS应用/服务的CPU活动性能
CPU Profiler 性能分析是用来分析CPU性能瓶颈的工具,可以实时查看应用/服务的CPU使用率和线程活动,也可以查看记录的方法跟踪数据、方法采样数据和系统跟踪数据的详情。基于CPU性能分析,您可以了解在一段时间内执行了哪些方法,以及…...
Linux:理解信号量以及内核中的三种通信方式
文章目录 共享内存的通信速度消息队列msggetmsgsndmsgrcvmsgctl 信号量semgetsemctl 内核看待ipc资源单独设计的模块ipc资源的维护 理解信号量总结 本篇主要是基于共享内存,延伸出对于消息队列和信号量,再从内核的角度去看这三个模块实现进程间通信 共享…...
【ArcGIS微课1000例】0100:ArcGIS for CAD软件下载与安装(附安装包)
ArcGIS for CAD软件下载与安装(附安装包)。 文章目录 一、ArcGIS for CAD概述1. ArcGIS for CAD介绍2. 主要功能二、ArcGIS for CAD下载三、ArcGIS for CAD安装1. 安装CAD2. 安装ArcGIS for CAD3. 配置一、ArcGIS for CAD概述 1. ArcGIS for CAD介绍 ArcGIS for CAD是Esri提…...
Django模型(一)
一、介绍 模型,就是python中的类对应数据库中的表 1.1、ORM ORM 就是通过实例对象的语法,完成关系型数据库的操作的技术,是"对象-关系映射"(Object/Relational Mapping) 的缩写 ORM 把数据库映射成对象 1.…...
【ChatGPT】文本向量化与余弦相似度:揭开文本处理的神秘面纱(5)
1、引言 在这个数字化的时代,我们每天都会面对大量的文本信息,从社交媒体到新闻报道,文本无处不在。但是,计算机要如何理解和处理这些文字呢?本文将为大家揭开其中的一些奥秘,详细解释文本向量化的概念&am…...
计算机中丢失mfc100u.dll怎么解决,详细解析mfc100u.dll丢失的解决方法
遭遇“无法找到mfc100u.dll”的错误不必过分担忧,这是一个普遍现象。许多用户在启动某些软件或游戏的时候可能会碰到这样的情况。通常,这个错误信息表明你的计算机系统中缺失了一个关键的动态链接库(DLL)文件,它可能会妨碍应用程序的顺利启动…...
代码随想录 Leetcode617.合并二叉树
题目: 代码(首刷看解析 2024年1月31日): class Solution { public:TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {if (!root1) return root2;if (!root2) return root1;root1->val root2->val;root1->left mergeTree…...
知识价值1-github站点域名
github如果访问不上,有一个办法是hosts映射: github.com x.x.x.x github.global.ssl.fastly.net y.y.y.y assets-cdn.github.com z.z.z.z1 assets-cdn.github.com z.z.z.z2 assets-cdn.github.com z.z.z.z3 assets-cdn.github.com z.z.z.z3 那这几个域名…...
【PyRestTest】进行Benchmarking测试
PyRestTest支持通过Curl请求本身收集比较差的网络环境下的性能指标。 基准测试:它们扩展了测试中的配置元素,允许你进行相似的REST调用配置。然而,它们不对HTTP响应情况进行验证,它只收集指标数据。 下列选项被指定用于benchmar…...
cocos creator 调用预设体Prefab中的方法(调用另一个节点的方法)
调用预设体中的方法 通过cc.instantiate(this.star)创建这个预设体实例这个star预设体中添加了一个脚本组件star.ts 获取到这个脚本组件star.getComponent(‘star’).test(),并调用其中的test()方法同理可以用该方式像另一个节点中传值 //星星预设体property(cc.Pr…...
Spring 学习2 --基于xml管理Bean
1、xml管理Bean <?xml version"1.0" encoding"UTF-8"?> <beans xmlns"http://www.springframework.org/schema/beans"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://www.springfr…...
面试:如果让你设计一个客服 Agent,你会如何划分四大组件的职责?
这个问题挺经典的,我之前负责过客服系统的设计,就结合我们线上的实践来说说。 核心就是四件事:定义角色、管理记忆、制定计划、执行动作 。 先说 Profile(角色定义) 。客服 Agent 得知道自己是谁、以什么姿态服务。我们当时设计的时候会预设几个维度:一个是基础信息,比…...
联想集团第一季营收216亿美元:净利5.9亿美元 股价上涨19% 市值近2000亿港元
雷递网 雷建平 5月22日联想集团(HKSE:0992;ADR:LNVGY)今日公布截至2026年3月31日的2025/26财年第四季度暨全年业绩。财报显示,联想集团2026年第一季度营收为215.88亿美元,较上年同期的169.84亿美…...
三年级下册语文第三单元作文:我做了一个小实验300字
三年级下册语文《我做了一个小实验》作文,重点要写清楚:做了什么实验实验前准备了什么实验过程看到了什么变化明白了什么道理我用夸克网盘分享了「三年级下册语文作文」,1-8单元。链接:https://pan.quark.cn/s/a80b7ca7f993这类作…...
给电力行业装上“地理大脑”:百度智能云图云做了一次“地址大模型”变革
“我家在老三中对面那条巷子,供电局以前的老院子旁边……”当95598客服接到这样的报修电话时,系统该如何精准定位?这并非个例。城市快速扩张、街巷小区不断新建更名,而电力系统的地址数据往往跟不上现实变化。同时,传统…...
还在熬夜起草各类通知?2026便捷AI办公好物,轻松写完正式公文
作为一名在行政岗摸爬滚打五年的职场人,我每天的工作不是泡在各类会议里,就是埋头起草通知、整理纪要。相信不少行政、文秘岗位的朋友都和我有一样的困扰:公司部门多、会议密,每周光是例会、项目协调会、临时部署会就要开三四场&a…...
【2026 Q1实测数据】ChatGPT新增“因果推理引擎”准确率提升至89.7%,但83%用户因忽略这4个参数设置导致失效
更多请点击: https://codechina.net 第一章:ChatGPT“因果推理引擎”的架构演进与2026 Q1实测基准 OpenAI于2025年Q4正式将ChatGPT核心推理模块重构为“因果推理引擎”(Causal Reasoning Engine, CRE),其本质是将传统…...
Python API认证与授权实战:从Basic Auth到OAuth2.0
Python API认证与授权实战:从Basic Auth到OAuth2.0 引言 API安全是后端开发中至关重要的一环。作为从Python转向Rust的后端开发者,我深刻体会到认证与授权机制的重要性。一个安全可靠的API需要完善的认证体系来保护敏感数据和资源。本文将从实战角度出…...
萨科微宋仕强“华强北山寨手机”研究
萨科微宋仕强“华强北山寨手机”研究(十六),手机的灰色产业链。华强北每个手机柜台背后都有灰色供应链支撑。如香港手机比华强北便宜,就通过各种渠道从香港走私过来。沙头角的中英街两边分属于香港和深圳,香港一侧的走…...
后端工程师知识库
后端工程师深度课程 中文知识库 一套面向中级到高级后端工程师的系统进阶课程,共 9 大专题、146 篇万字长文,每篇含底层原理、代码示例、生产实践、陷阱清单与练习题。 📅 内容基准:2026 年 5 月 —— HTTP/3 主流、TLS 1.3 pos…...
3小时变3分钟:用ChanlunX插件让通达信自动绘制缠论结构
3小时变3分钟:用ChanlunX插件让通达信自动绘制缠论结构 【免费下载链接】ChanlunX 缠中说禅炒股缠论可视化插件 项目地址: https://gitcode.com/gh_mirrors/ch/ChanlunX 你是否曾经面对复杂的K线图,试图手工画出缠论中的笔、线段和中枢࿰…...
