当前位置: 首页 > MySQL数据库

Mysql数据库应用常见的问题有哪些

时间:2026-01-28 12:53:49
一、安装mysql1、CentOS系统

1.)安装mysql

$ wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm$ sudo rpm -ivh mysql-community-release-el7-5.noarch.rpm
$ sudo yum install -y mysql-server

2.)启动/重启/关闭服务

service mysqld start | restart | stop
2、alpine系统
$ apk update# 安装数据库及客户端$ apk add mysql mysql-client# 初始化数据库$ mysql_install_db --user=mysql --datadir=/var/lib/mysql# 启动服务$ rc-service mariadb start  # 若没有rc,安装:apk add openrc# 修改密码$ mysqladmin -u root password '新root密码'# 加入开机启动$ rc-update add mariadb default
二、操作mysql1、登录数据库
$ mysql
$ mysql -uroot -p# 一次性登录$ mysql -u用户 -p密码
2、操作数据库
# 查看所有数据库mysql> show databases;# 创建数据库mysql> create database xxx charset=utf8;# 删除数据库mysql> drop database xxx;# 切换数据库mysql> use mysql;# 查看表mysql> show tables;# 创建表mysql> create table xxx (    id int,    name varchar(20),    update_time datetime);# 删除表mysql> drop table xxx;# 显示表结构mysql> desc xxx;# 查询指定a,b字段的记录,不知道用*代替mysql> select a,b form xxx;# 插入记录mysql> insert into xxx(id,user) values(1,'wang',now());# 删除记录mysql> delete from xxx where name='wang';# 清屏命令mysql> system clear;# 退出mysql> quit;
3、用户管理

mysql的user表用来存储所有用户权限,其中host字段表示指定ip用户能使用,同名不同host的为两个用户,host常见值如下:

下面新建/删除用户操作时,可通过user@'host'指定,若不指定默认为%

# 切换到mysql权限数据库mysql> use mysql;# 查看用户及所属的hostmysql> select user,host from user;# 新建用户并设置密码mysql> create user '用户名' identified by '密码';# 上面不指定host,默认%,等同于:mysql> create user '用户名'@'%' identified by '密码';# 删除用户(只删除host为%的用户)mysql> drop user '用户名';# 查看用户权限mysql> show grants for '用户名';# 设置权限,并指定数据库mysql> grant all privileges on xxxDB.* to '用户名';# 修改密码,注意密码处不能直接password='新密码'mysql> update user set password=password('新密码') where user='用户名';# 刷新权限表mysql> flush privileges;
4、批量操作

1.)sql脚本批量执行

$ mysql -uroot -p -Dxxx < ./init.sql    # xxx为数据库

2.)备份/恢复数据库

$ mysqldump --all-databases -h227.0.0.1 -u root -p > ./backup/mysql-bak.sql$ mysqldump --all-databases -h227.0.0.1 -u root -p < ./backup/mysql-bak.sql
三、常见问题1、root密码忘记怎么擦除?
$ mysql –skip-grant-table &  mysql> use mysql;  mysql> update user set password=password('新密码') where user='root';  mysql> flush privileges;  mysql> quit;
2、空用户错误

ERROR 1044 (42000): Access denied for user ''@'localhost' to database 'mysql'错误:

原因:

处理方案:

# 1.关闭mysql$ service mysqld stop# 2.屏蔽权限$ mysqld_safe --skip-grant-table # 屏幕出现: Starting demo from .....# 3.新开起一个终端输入$ mysql -uroot mysql  mysql> update user set password=password('新密码') where user='root';  mysql> flush privileges;  mysql> quit;
3、服务上root能用,远程不能登录
$ mysql -uroot -p  mysql> use mysql;    # 先查看user表host字段,有无通配符'%',若有直接运行flush privileges;  mysql> select host from user where user='root';    mysql> grant all privileges *.* to 'root'@'%' identified by 'root密码';  mysql> flush privileges;  mysql> quit;
4、远程连接提示caching_sha2_password错误
mysql> use mysql;mysql> alter user 'root'@'%' identified with mysql_native_password by 'root密码';
5、mysql修改默认数据存放
$ mysqladmin -u root -p variables | grep datadir  # 查看mysql数据库存放目录$ service mysqld stop$ mv /var/lib/mysql /路径  # 移动数据库文件$ vi /etc/my.cnf# 修改datadir和socket两个字段,并添加以下:[mysql] socket=/路径/mysql.sock$ service mysqld start

上一篇:select查询语句该如何执行
下一篇:mysql怎么删数据库
mysql
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器
  • 英特尔第五代 Xeon CPU 来了:详细信息和行业反应
  • 由于云计算放缓引发扩张担忧,甲骨文股价暴跌
  • Web开发状况报告详细介绍可组合架构的优点
  • 如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳
  • 美光在数据中心需求增长后给出了强有力的预测
  • 2027服务器市场价值将接近1960亿美元
  • 生成式人工智能的下一步是什么?
  • 分享在外部存储上安装Ubuntu的5种方法技巧
  • 全球数据中心发展的关键考虑因素
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器

    英特尔第五代 Xeon CPU 来了:详细信息和行业反应

    由于云计算放缓引发扩张担忧,甲骨文股价暴跌

    Web开发状况报告详细介绍可组合架构的优点

    如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳

    美光在数据中心需求增长后给出了强有力的预测

    2027服务器市场价值将接近1960亿美元

    生成式人工智能的下一步是什么?

    分享在外部存储上安装Ubuntu的5种方法技巧

    全球数据中心发展的关键考虑因素