当前位置: 首页 > news >正文

(三)Mysql 数据库系统全解析

一、Mysql 数据库

  1. 数据库的作用和优势

    • 作用:集中化存储结构性的数据。
    • 优势
      • 减小数据冗余,避免数据的重复存储。
      • 保证数据的真实有效和唯一性,提高数据的质量。
      • 方便数据共享访问,使得不同的用户和应用可以方便地获取所需数据。
      • 集中化管理方便数据备份,确保数据的安全性。
    • Mysql 数据库特点
      • 支持多进程多用户,可以同时为多个用户和进程提供服务。
      • 采用 C/S 设计结构,客户端和服务器分离,提高了系统的可扩展性和灵活性。
      • 简单易用支持图形化界面,方便用户进行操作和管理。
      • 安全可靠,提供了多种安全机制保障数据的安全。
  2. 常见数据库厂商

    • Oracle 甲骨文:旗下的 Mysql 开源免费且跨平台,而 Oracle 数据库收费闭源且跨平台。
    • Microsoft:Sql Server 是微软的数据库产品,只能运行在 Windows 平台使用。
  3. 安装 Mysql 依赖程序和创建管理组和用户

    • 安装依赖程序,使用命令[root@centos01 ~]# yum -y install ncurses-devel cmake
    • 创建管理 Mysql 服务组,使用命令[root@centos01 ~]# groupadd mysql
    • 创建用户加入 Mysql 组管理 Mysql 服务,使用命令[root@centos01 ~]# useradd -M -s /sbin/nologin -g mysql mysql

二、安装配置 Mysql 服务

  1. 解压配置 Mysql

    • 解压缩源代码程序,使用命令[root@centos01 ~]# tar zxf /mnt/mysql-5.5.22.tar.gz -C /usr/src/,然后切换到源代码目录[root@centos01 ~]# cd /usr/src/mysql-5.5.22/
    • 配置源代码 Mysql,使用命令[root@centos01 mysql-5.5.22]# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql/ -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=all -DSYSCONFDIR=/etc,指定安装位置、默认字符编码、检验字符编码、支持更多字符编码以及初始化 Mysql 参数临时存储目录。
    • 编译安装 Mysql,使用命令[root@centos01 mysql-5.5.22]# make && make install
    • 检查是否创建安装目录,使用命令[root@centos01 mysql-5.5.22]# ls -ld /usr/local/mysql/
  2. 生成配置文件和服务控制文件

    • 生成配置文件,使用命令[root@centos01 mysql-5.5.22]# cp support-files/my-medium.cnf /etc/my.cnf
    • 生成服务控制文件,使用命令[root@centos01 mysql-5.5.22]# cp support-files/mysql.server /etc/init.d/mysqld
    • 添加执行权限,使用命令[root@centos01 mysql-5.5.22]# chmod +x /etc/init.d/mysqld
    • 添加系统服务,使用命令[root@centos01 mysql-5.5.22]# chkconfig --level 35 mysqld on,然后切换到主目录[root@centos01 mysql-5.5.22]# cd
  3. 优化 Mysql 命令

    • 优化 Mysql 命令,在/etc/profile文件中添加PATH=$PATH:/usr/local/mysql/bin/
    • 更新优化命令,使用命令[root@centos01 ~]# source /etc/profile
    • 初始化 Mysql,使用命令[root@centos01 ~]# /usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/
  4. 启动 Mysql 服务设置密码登录 Mysql

    • 启动 Mysql 服务,使用命令[root@centos01 ~]# systemctl start mysqld
    • 监听 Mysql 进程,使用命令[root@centos01 ~]# netstat -anptu | grep mysqld
    • 设置密码,使用命令[root@centos01 ~]# mysqladmin -uroot password
    • 登录 Mysql 数据库,使用命令[root@centos01 ~]# mysql -uroot -密码
    • 退出 Mysql,在 Mysql 命令行中输入exit

三、Mysql 数据库表记录管理授权

  1. 数据库管理

    • 查看数据库,在 Mysql 命令行中输入show databases;
    • 创建数据库名字,使用命令create database 名字;
    • 删除数据库,使用命令drop database 名字;
    • 创建并切换到数据库,使用命令create database benet;创建 benet 数据库,然后使用use benet;切换到 benet 数据库中。
  2. 表的管理

    • 创建表设计表结构表的名字 student 放在 benet 数据库中,使用命令create table benet.student (学号 int,姓名 char(7),性别 char(4),身份证号码 char(18),primary key (身份证号码));
    • 查看表,先使用use benet;切换到 benet 数据库,然后使用show tables;查看创建的表。
    • 删除 student 表,可以使用drop table student;drop table benet.student;
  3. 表中记录管理

    • 查看表结构,使用命令desc student;
    • 插入连续列数据到 student 表,使用命令insert into benet.student values (1,"名字","男","111111111111111111");
    • 插入不连续列,使用命令insert into benet.student (学号,姓名,身份证号码) values (2,'名字','22222222222222222');
    • 查询 Mysql 数据,使用命令select * from benet.student;
    • 修改数据,如将姓名是名字的性别修改为男,使用命令update benet.student set 性别="男" where 姓名="名字";,修改多列值可以使用update benet.student set 学号="3",性别="女" where 姓名="名字";
    • 查看指定列数据,使用命令select 姓名,身份证号码 from benet.student;
    • 删除匹配条件的用户,使用命令delete from benet.student where 姓名="用户";
    • 清空表中数据,使用命令delete from benet.student;
  4. Mysql 数据库授权

    • Mysql 数据库权限类型
      • all:完全控制权限。
      • insert:插入数据。
      • delete:删除数据。
      • update:修改数据。
      • select:查询权限。
    • 安装 Mysql 客户端,使用命令[root@centos02 ~]# yum -y install mariadb-devel mariadb
    • 授权 bob 用户通过主机 192.168.100.20 访问 Mysql 服务器密码为 密码,允许访问 benet 数据库下所有表进行插入数据,使用命令mysql> grant insert on benet.* to 'bob'@'192.168.100.20' identified by '密码';
    • 客户端远程登录,使用命令[root@centos02 ~]# mysql -h 192.168.100.10 -ubob -密码 客户端名字
    • 查看用户访问 mysql 数据库权限,使用命令mysql> show grants for 'bob'@"192.168.100.20";
    • 授权完全控制权限,使用命令mysql> grant all on benet.* to 'tom'@'192.168.100.30' identified by 'pwd@12345';
    • 撤销授权,使用命令mysql> revoke all on benet.* from 'tom'@'192.168.100.30';
    • 更新数据库,使用命令mysql> flush privileges;

通过以上步骤,我们可以成功安装、配置和管理 Mysql 数据库,实现对数据库表的创建、查询、修改和删除等操作,以及进行数据库授权管理,确保数据的安全和有效访问。

相关文章:

(三)Mysql 数据库系统全解析

一、Mysql 数据库 数据库的作用和优势 作用:集中化存储结构性的数据。优势: 减小数据冗余,避免数据的重复存储。保证数据的真实有效和唯一性,提高数据的质量。方便数据共享访问,使得不同的用户和应用可以方便地获取所需…...

SAP HCM 0001信息类型一个月内有多个成本中心

一般跨部门调动时候,成本中心都会变化,SAP默认都是读取wpbp的最后一一条数据,但是今天过账会读取两个单位的成本中心,一直都觉得很奇怪,SAP如何都拆分出这样的情况, 没办法只有debug,初始化系统…...

字节输入流

1.是什么 字节输入流(Byte Input Stream)在Java中是用来读取原始字节流的数据。Java的java.io包提供了多种字节输入流类,其中InputStream是所有字节输入流类的超类。以下是关于字节输入流的详细解释和举例: 字节输入流的概念&…...

深度学习-----------------机器翻译与数据集

目录 机器翻译与数据集下载和预处理数据集预处理步骤词元化词汇表该部分总代码 固定长度阶段或填充该部分总代码 转换成小批量数据集用于训练训练模型总代码 机器翻译与数据集 import os import torch from d2l import torch as d2l下载和预处理数据集 #save d2l.DATA_HUB[fr…...

SOMEIP_ETS_151: SD_Send_triggerEventUINT8Reliable_Eventgroup_2

测试目的: 验证DUT在Tester订阅事件组后,能够响应Tester触发的triggerEventUINT8Reliable方法,并将TestEventUINT8Reliable事件发送到订阅请求中端点选项指定的IP地址和端口。 描述 本测试用例旨在确保DUT能够正确处理事件组的订阅请求&am…...

32 C 语言指针的长度与运算(指针加减整数、指针自增自减、同类型指针相减、指针的比较运算)

目录 1 指针的长度 2 指针与整数的加减运算 3 指针自增与自减 4 同类型指针相减 5 指针的比较运算 6 测试题 1 指针的长度 在 C 语言中,sizeof 运算符可以用来计算指针的长度。指针的长度实际上与指针所指向的数据类型无关,而是与系统的位数&…...

【系统架构设计师】经典论文:轮软件三层架构设计

更多内容请见: 备考系统架构设计师-核心总结目录 文章目录 摘要正文总结摘要 本人于 2022 年 1 月参与了中石化 XX 油田 XX 采油厂“用电管理系统”的项目建设,该系统建设目标是实现分单位、分线路、分系统评价、优化、考核,全面提升采油厂用 电管理水平。在该项目组中我担…...

(C语言贪吃蛇)13.实现贪吃蛇四方向的移动

目录 前言 原代码预览 解决方法⚠️ 运行效果 总结 前言 我们上节通过Linux线程实现了两个while(1)同时运行,这样就可以一边控制方向一遍刷新出贪吃蛇的身体节点了。本节我们就来实现贪吃蛇四方向的移动。 (此图片为最终效果) 原代码预览 我们之前的代码是通过…...

Spring Boot + MyBatis 项目中常用注解详解(万字长篇解读)

Spring Boot MyBatis 项目中常用注解详解 在现代Java开发中,Spring Boot和MyBatis是两大热门框架,广泛应用于构建高效、可维护的企业级应用。两者结合使用,可以充分发挥各自的优势,提高开发效率和代码质量。在这个过程中&#x…...

AWS Network Firewall -NAT网关配置只应许白名单域名出入站

1. 创建防火墙 选择防火墙的归属子网(选择公有子网) 2. 创建规则白名单域名放行 3. 绑定相关规则 继续往下拉 绑定非托管规则 4. 配置网络路由 相关规则 参考图 解释 防火墙的归属公有子网路由表规则机器实例的规则子网路由表规则nat网管路…...

【C语言系统编程】【第二部分:并发编程】2.3 实践与案例分析

2.3 实践与案例分析 2.3.1 案例分析:多线程文件搜索程序 本文中,我们将通过一个多线程文件搜索程序的案例,展示如何在实际项目中应用多线程编程技术,并具体介绍任务分解、线程创建、结果汇总及锁机制的应用。 2.3.1.1 任务分解…...

React -AppVarContext.Provider 提供者组件

AppVarContext.Provider 是一个 React 上下文提供者,通常用于在组件树中提供共享的状态或数据。下面将详细解释 AppVarContext.Provider 的作用和如何使用它。展示如何使用 AppVarContext.Provider 来管理全局状态 1. 什么是上下文(Context)…...

【Python】解密用户代理:使用 Python User Agents 库探索浏览器和设备信息

Python User Agents 是一个专为解析 User Agent 字符串而设计的 Python 库。它能够轻松识别访问设备的类型(如移动设备、桌面设备或平板),并获取设备、浏览器、操作系统等详细信息。借助它,开发者可以更好地了解访问用户的设备属性…...

以串口接口为例介绍关于BSP底层架构开发的迭代过程

以串口接口为例介绍关于BSP底层架构开发的迭代过程 文章目录 以串口接口为例介绍关于BSP底层架构开发的迭代过程架构概述初代BSP二代BSP:三代BSP:四代BSP:架构概述 单片机开发有四个阶段: 阶段一:单一单片机的功能实现阶段 此阶段你开始熟悉STM32F1系列的单片机,并利用…...

Label-Studio ML利用yolov8模型实现自动标注

引言 Label Studio ML 后端是一个 SDK,用于包装您的机器学习代码并将其转换为 Web 服务器。Web 服务器可以连接到正在运行的 Label Studio 实例,以自动执行标记任务。我们提供了一个示例模型库,您可以在自己的工作流程中使用这些模型&#x…...

【PostgreSQL】实战篇——用户管理、角色和权限控制的高级用法及技巧

数据库中用户管理、角色和权限控制不仅仅是基础的安全措施,更是实现复杂应用需求和优化数据库性能的重要手段。 通过深入理解这些概念,数据库管理员可以更有效地管理用户访问、确保数据安全,并优化系统性能。以下是对这些概念的详细介绍以及…...

Leetcode: 0011-0020题速览

Leetcode: 0011-0020题速览 本文材料来自于LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解 遵从开源协议为知识共享 版权归属-相同方式…...

Hive数仓操作(七)

一、 Hive动态分区表 1. 动态分区与静态分区的区别 分区定义: 静态分区:在插入数据时,需要手动指定分区字段的值。动态分区:分区字段的值是根据数据中的某个字段自动生成的,用户只需指定分区字段的类型。 数据加载方…...

Redis进阶篇 - 缓存穿透、缓存击穿、缓存雪崩问题及其解决方案

文章目录 1 文章概述2 缓存穿透2.1 什么是缓存穿透?2.2 缓存穿透的解决方法2.2.1 做好参数校验2.2.2 缓存无效Key2.2.3 使用布隆过滤器2.2.4 接口限流 3 缓存击穿3.1 什么是缓存击穿?3.2 缓存击穿的解决方法3.2.1 调整热点数据过期时间3.2.2 热点数据预热…...

一天认识一个硬件之电源

无论是台式机还是笔记本,都离不开电源,台式机和笔记本电脑的电源都承担着将交流电转换为直流电,并为电脑内部各个部件提供稳定电力供应的重要任务。今天就来分享一下台式机和笔记本的电源区别 设计和功率 台式机电源:设计为内置…...

大模型多显卡多服务器并行计算方法与实践指南

一、分布式训练概述 大规模语言模型的训练通常需要分布式计算技术,以解决单机资源不足的问题。分布式训练主要分为两种模式: 数据并行:将数据分片到不同设备,每个设备拥有完整的模型副本 模型并行:将模型分割到不同设备,每个设备处理部分模型计算 现代大模型训练通常结合…...

成都鼎讯硬核科技!雷达目标与干扰模拟器,以卓越性能制胜电磁频谱战

在现代战争中,电磁频谱已成为继陆、海、空、天之后的 “第五维战场”,雷达作为电磁频谱领域的关键装备,其干扰与抗干扰能力的较量,直接影响着战争的胜负走向。由成都鼎讯科技匠心打造的雷达目标与干扰模拟器,凭借数字射…...

AspectJ 在 Android 中的完整使用指南

一、环境配置(Gradle 7.0 适配) 1. 项目级 build.gradle // 注意:沪江插件已停更,推荐官方兼容方案 buildscript {dependencies {classpath org.aspectj:aspectjtools:1.9.9.1 // AspectJ 工具} } 2. 模块级 build.gradle plu…...

Web 架构之 CDN 加速原理与落地实践

文章目录 一、思维导图二、正文内容(一)CDN 基础概念1. 定义2. 组成部分 (二)CDN 加速原理1. 请求路由2. 内容缓存3. 内容更新 (三)CDN 落地实践1. 选择 CDN 服务商2. 配置 CDN3. 集成到 Web 架构 &#xf…...

以光量子为例,详解量子获取方式

光量子技术获取量子比特可在室温下进行。该方式有望通过与名为硅光子学(silicon photonics)的光波导(optical waveguide)芯片制造技术和光纤等光通信技术相结合来实现量子计算机。量子力学中,光既是波又是粒子。光子本…...

iOS性能调优实战:借助克魔(KeyMob)与常用工具深度洞察App瓶颈

在日常iOS开发过程中,性能问题往往是最令人头疼的一类Bug。尤其是在App上线前的压测阶段或是处理用户反馈的高发期,开发者往往需要面对卡顿、崩溃、能耗异常、日志混乱等一系列问题。这些问题表面上看似偶发,但背后往往隐藏着系统资源调度不当…...

【C++特殊工具与技术】优化内存分配(一):C++中的内存分配

目录 一、C 内存的基本概念​ 1.1 内存的物理与逻辑结构​ 1.2 C 程序的内存区域划分​ 二、栈内存分配​ 2.1 栈内存的特点​ 2.2 栈内存分配示例​ 三、堆内存分配​ 3.1 new和delete操作符​ 4.2 内存泄漏与悬空指针问题​ 4.3 new和delete的重载​ 四、智能指针…...

PHP 8.5 即将发布:管道操作符、强力调试

前不久,PHP宣布了即将在 2025 年 11 月 20 日 正式发布的 PHP 8.5!作为 PHP 语言的又一次重要迭代,PHP 8.5 承诺带来一系列旨在提升代码可读性、健壮性以及开发者效率的改进。而更令人兴奋的是,借助强大的本地开发环境 ServBay&am…...

二维FDTD算法仿真

二维FDTD算法仿真,并带完全匹配层,输入波形为高斯波、平面波 FDTD_二维/FDTD.zip , 6075 FDTD_二维/FDTD_31.m , 1029 FDTD_二维/FDTD_32.m , 2806 FDTD_二维/FDTD_33.m , 3782 FDTD_二维/FDTD_34.m , 4182 FDTD_二维/FDTD_35.m , 4793...

TJCTF 2025

还以为是天津的。这个比较容易,虽然绕了点弯,可还是把CP AK了,不过我会的别人也会,还是没啥名次。记录一下吧。 Crypto bacon-bits with open(flag.txt) as f: flag f.read().strip() with open(text.txt) as t: text t.read…...