• 技术文章 >数据库 >mysql教程

    一文总结Mysql数据库应用及常见问题

    藏色散人藏色散人2022-01-24 10:54:34转载469

    一、安装mysql

    1、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

    二、操作mysql

    1、登录数据库

    默认初始化直接登录
    $ 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 -h127.0.0.1 -u root -p > ./backup/mysql-bak.sql
    $ mysqldump --all-databases -h127.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视频教程

    以上就是一文总结Mysql数据库应用及常见问题的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:segmentfault,如有侵犯,请联系admin@php.cn删除
    专题推荐:mysql
    上一篇:mysql学习之select查询语句到底是怎么执行的? 下一篇:一起聊聊MySQL数据查询太多会OOM吗
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【腾讯云】年中优惠,「专享618元」优惠券!• mysql需要配置环境变量吗• mysql怎么实现除法保留两位小数• mysql要如何删数据库• mysql学习之select查询语句到底是怎么执行的?
    1/1

    PHP中文网