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

46次阅读
没有评论

共计 3431 个字符,预计需要花费 9 分钟才能阅读完成。

这篇文章主要介绍“Mysql 数据库应用常见的问题有哪些”的相关知识,丸趣 TV 小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Mysql 数据库应用常见的问题有哪些”文章能帮助大家解决问题。

一、安装 mysql1、CentOS 系统

1.)安装 mysql

下载并安装 mysql 的 repo 源

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

安装 mysql

$ sudo yum install -y mysql-server

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

service mysqld start | restart | stop

2、alpine 系统 alpine 系统中安装 mysql 实际是开源的 MariaDB,MariaDB 数据库是 MySQL 的一个分支 / 衍生版,完全兼容 MySQL,并在扩展功能、存储引擎以及一些新的功能改进方面都强过 MySQL,安装参考

$ 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 常见值如下:

localhost:只能服务器端上使用  
192.168.4.%:指定 ip 段能用  
%:通配符,表示所有 ip 用户都能用,多用于远程连接

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

#  切换到 mysql 权限数据库
mysql  use mysql;
#  查看用户及所属的 host
mysql  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;

这里需要注意的是每句命令需要用分号“;”结尾, 执行完以上得操作,root 的密码就被清空。2、空用户错误

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

原因:

mysql 数据库的 user 表里,存在用户名为空的账户即匿名账户,导致登录的时候虽然用的是 root,但实际是匿名登录的。

处理方案:

# 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 错误从 mysql5.7 版本之后,默认采用了 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

关于“Mysql 数据库应用常见的问题有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注丸趣 TV 行业资讯频道,丸趣 TV 小编每天都会为大家更新不同的知识点。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-15发表,共计3431字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)