数据库基本命令--忘记密码数据库的增删改查
Posted givenchy_yzl
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据库基本命令--忘记密码数据库的增删改查相关的知识,希望对你有一定的参考价值。
数据库相关操作详解
1. 启动查看
[root@egon ~]# systemctl start mariadb #启动
[root@egon ~]# systemctl enable mariadb #设置开机自启动
Created symlink from /etc/systemd/system/multi-user.target.wants/mariadb.service to /usr/lib/systemd/system/mariadb.service.
[root@egon ~]# ps aux |grep mysqld |grep -v grep #查看进程,mysqld_safe为启动mysql的脚本文件,内部调用mysqld命令
mysql 3329 0.0 0.0 113252 1592 ? Ss 16:19 0:00 /bin/sh /usr/bin/mysqld_safe --basedir=/usr
mysql 3488 0.0 2.3 839276 90380 ? Sl 16:19 0:00 /usr/libexec/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib64/mysql/plugin --log-error=/var/log/mariadb/mariadb.log --pid-file=/var/run/mariadb/mariadb.pid --socket=/var/lib/mysql/mysql.sock
[root@egon ~]# netstat -an |grep 3306 #查看端口
tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN
[root@egon ~]# ll -d /var/lib/mysql #权限不对,启动不成功,注意user和group
drwxr-xr-x 5 mysql mysql 4096 Jul 20 16:28 /var/lib/mysql
安装完mysql 之后,登陆以后,不管运行任何命令,总是提示这个
mac mysql error You must reset your password using ALTER USER statement before executing this statement.
解决方法:
step 1: SET PASSWORD = PASSWORD('your new password');
step 2: ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;
step 3: flush privileges;
2. 登录,设置密码
初始状态下,管理员root,密码为空,默认只允许从本机登录localhost
设置密码
[root@egon ~]# mysqladmin -uroot password "123" 设置初始密码 由于原密码为空,因此-p可以不用
[root@egon ~]# mysqladmin -uroot -p"123" password "456" 修改mysql密码,因为已经有密码了,所以必须输入原密码才能设置新密码
命令格式:
[root@egon ~]# mysql -h172.31.0.2 -uroot -p456
[root@egon ~]# mysql -uroot -p
[root@egon ~]# mysql 以root用户登录本机,密码为空
3. 忘记密码时,修改密码的两种方式
linux平台下,破解密码的两种方式
方式一:直接删库(不提倡,除非是新创的库,里面没有任何数据)
[root@egon ~]# rm -rf /var/lib/mysql/mysql #所有授权信息全部丢失!!!
[root@egon ~]# systemctl restart mariadb
[root@egon ~]# mysql
方式二:选择跳过密码
[root@egon ~]# vim /etc/my.cnf #mysql主配置文件
[mysqld]
skip-grant-table
[root@egon ~]# systemctl restart mariadb
[root@egon ~]# mysql
MariaDB [(none)]> update mysql.user set password=password("123") where user="root" and host="localhost";
MariaDB [(none)]> flush privileges;
MariaDB [(none)]> \\q
[root@egon ~]# #打开/etc/my.cnf去掉skip-grant-table,然后重启
[root@egon ~]# systemctl restart mariadb
[root@egon ~]# mysql -u root -p123 #以新密码登录
4.修改数据库的字符编码
[root@db01 ~]# vim /etc/my.cnf
[mysqld]
datadir=/var/lib/mysql
character-set-server=utf8mb4
socket=/var/lib/mysql/mysql.sock
[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4
基本数据库操作语句(增删改查)
库---->文件夹
增
create database db1 charset utf8mb4;
改
alter database db1 charset gbk;
查
show databases;
show create database db1;
删
drop database db1;
表---->文件
create database db1;
use db1;
增
create table t1(id int,name varchar(16));
改
alter table t1 modify name varchar(20);
查
show tables;
desc t1;
show create table t1;
删
drop table t1;
记录---->信息
create database db1;
use db1;
create table t1(id int,name varchar(16));
增
insert db1.t1 values(1,"egon"),(2,"tom"),(3,"jack");
insert db1.t1(name,id) values("lili",4);
insert db1.t1(id) values(5);
改
update db1.t1 set name="JACK" where id=3;
查
select * from db1.t1;
select id,name from db1.t1;
select id,name from db1.t1 where id=3;
select id,name from db1.t1 where id<3;
删
delete from db1.t1 where id=3;
清空表:
delete from t1; #如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始。
truncate table t1;数据量大,删除速度比上一条快,且直接从零开始,
auto_increment 表示:自增
primary key 表示:约束(不能重复且不能为空);加速查找
以上是关于数据库基本命令--忘记密码数据库的增删改查的主要内容,如果未能解决你的问题,请参考以下文章