mysql数据库管理

查看数据库结构

Mysql是一套数据库管理系统,在每台Mysql服务器中,支持运行多个数据库每一个数据库相当一个容器

1:查看数据库结构

复制代码
[root@localhost ~]# mysql -u root -ppwd123

mysql> show databases;

mysql> use mysql

mysql> show tables;

mysql> describe user;

mysql> select * from user\G;

备注:

  • information_schema数据库:保存着关于MySQL服务器所维护的所有其他数据库的信息。如数据库名,数据库的表,表栏的数据类型与访问权 限等
  • performance_schema:用于监控MySQL server在一个较低级别的运行过程中的资源消耗、资源等待等情况
  • mysql:是 MySQL 服务正常运行所需的数据库,其中包含了用户认证相关的表

2:创建及删除数据库和表

(1)创建新库

复制代码
mysql> create database auth;

(2)创建新表

mysql> use auth;

mysql> CREATE TABLE users (user_name CHAR(16) NOT NULL, user_passwd CHAR(48) DEFAULT '', PRIMARY KEY (user_name));

备注:

DEFAULT '' 密码默认为空

(3)删除一个数据表

mysql> DROP TABLE auth.users;

(4)删除一个数据库

mysql>DROP DATABASE auth;

3:SQL语言

DDL:数据定义语言(create、drop、alter)

DML:数据操纵语言(insert、update、delete)

DQL:数据查询语言(select)

DCL:数据控制语言(grant、revoke、commit、rollback)

3:管理表中的数据记录

(1)插入数据记录

mysql>use auth;

mysql>INSERT INTO users(user_name,user_passwd) VALUES('zhangsan', PASSWORD ('123456'));

mysql>INSERT INTO users VALUES('lisi', PASSWORD('654321'));

(2)查询数据记录

复制代码
mysql>select * from auth.users;

mysql>SELECT user_name,user_passwd FROM auth.users WHERE user_name='zhangsan';

(3)修改数据记录

mysql>UPDATE auth.users SET user_passwd=PASSWORD('') WHERE user_name= 'lisi';

mysql>SELECT * FROM auth.users;

mysql>UPDATE mysql.user SET authentication_string=PASSWORD('123457') WHERE user='root';

mysql>FLUSH PRIVILEGES;/

root@www \~\]# **mysqladmin -u root -p'123457' password '123456'** (4)删除数据记录 mysql\>**DELETE FROM auth.users WHERE user_name='lisi';** mysql\>**SELECT \* FROM auth.users;** 4:数据库表高级操作 (1)删除表 mysql\> delete from user01 where user_name='zhangsan'; mysql\>**delete from user01;** mysql\>**insert into user01 select \* from auth.users;** mysql\>**truncate table user01;** mysql\>**select count(\*) from user01;** (2)临时表 mysql\>**select \* from mytmp;**//查看 mytmp 表是否存在 mysql\>**CREATE TEMPORARY TABLE \`mytmp\` (** **\`id\` int(10) NOT NULL AUTO_INCREMENT,** **\`NAME\` varchar(32) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL,** **\`level\` int(10) NOT NULL,** **PRIMARY KEY (id)** ) **ENGINE=InnoDB DEFAULT CHARSET=utf8; //**创建临时表 mysql\> **insert into mytmp(name,level) values('aa',10);**//插入数据 Query OK, 1 row affected (0.01 sec) mysql\>**select \* from mytmp;** mysql\>**quit**//退出当前连接 Bye mysql\>**select \* from mytmp;**//重新连接 MySQL 之后查看临时表状态 二:数据库用户授权 1:授予权限 mysql\>**GRANT select ON auth.\* TO 'zhangsan'@'localhost' IDENTIFIED BY '123456';** 2:查看权限 mysql\> SHOW GRANTS FOR 'zhangsan'@'localhost'; 3:验证权限 \[root@localhost \~\]# mysql -u zhangsan -p123456 mysql\> select \* from auth.users; mysql\> select \* from mysql.user; 备注: zhangsan用户可以查看auth数据库的表,但不能查看mysql数据库的表。 4:撤销权限 mysql\> revoke all on auth.\* from zhangsan@'localhost'; \[root@localhost \~\]# mysql -u zhangsan -p123456 mysql\> select \* from mysql.user; 撤销权限后,已经无法查看auth中的表

相关推荐
积跬步,慕至千里18 分钟前
clickhouse数据库表和doris数据库表迁移starrocks数据库时建表注意事项总结
数据库·clickhouse
极限实验室1 小时前
搭建持久化的 INFINI Console 与 Easysearch 容器环境
数据库
星辰离彬1 小时前
Java 与 MySQL 性能优化:Java应用中MySQL慢SQL诊断与优化实战
java·后端·sql·mysql·性能优化
白仑色1 小时前
Oracle PL/SQL 编程基础详解(从块结构到游标操作)
数据库·oracle·数据库开发·存储过程·plsql编程
程序猿小D3 小时前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的个人财务管理系统,推荐!
java·数据库·mysql·spring·毕业论文·ssm框架·个人财务管理系统
钢铁男儿4 小时前
C# 接口(什么是接口)
java·数据库·c#
__风__4 小时前
PostgreSQL kv(jsonb)存储
数据库·postgresql
轩情吖4 小时前
Qt的第一个程序(2)
服务器·数据库·qt·qt creator·qlineedit·hello world·编辑框
Databend4 小时前
Databend 产品月报(2025年6月)
数据库
Little-Hu5 小时前
QML TextEdit组件
java·服务器·数据库