>데이터 베이스 >MySQL 튜토리얼 >한 기사에서는 MySQL 데이터베이스 애플리케이션과 일반적인 문제를 요약합니다.

한 기사에서는 MySQL 데이터베이스 애플리케이션과 일반적인 문제를 요약합니다.

藏色散人
藏色散人앞으로
2022-01-07 15:14:262610검색

1. mysql

1, CentOS 시스템

1을 설치합니다.) mysql

설치 mysql
$ 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의 repo 소스를 다운로드하여 설치합니다. ) 서비스 시작/재시작/종료

service mysqld start | restart | stop

2. 알파인 시스템

알파인 시스템에 mysql을 설치하는 것은 실제로 오픈 소스 MariaDB이며 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

2. 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의 사용자 테이블은 모든 사용자 권한을 저장하는 데 사용됩니다. 호스트 필드는 지정된 IP 사용자가 이를 사용할 수 있음을 나타냅니다. 이름이 같고 호스트가 다른 사용자. 일반적인 호스트 값은 다음과 같습니다.

localhost: 서버 측에서만 사용할 수 있습니다.
192.168.4.%: 지정된 IP 세그먼트를 사용할 수 있습니다.
%: 와일드카드 , 모든 IP 사용자가 사용할 수 있음을 나타내며 주로 원격 연결에 사용됩니다.

아래 사용자를 생성/삭제할 때 지정된 user@' 호스트'를 사용할 수 있으며, 지정하지 않은 경우 기본값은 %

# 切换到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

3. 자주 묻는 질문

1, 루트 비밀번호를 잊어버린 경우 어떻게 삭제하나요?

$ 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): ''@'localhost' 사용자의 데이터베이스 'mysql'에 대한 액세스가 거부되었습니다. 오류:

원인:

다음 사용자 테이블에 사용자 이름이 있습니다. 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. 서비스에서 루트를 사용할 수 있지만 원격 로그인을 할 수 없습니다.

$ 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.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제