MySQL面试必备:基础命令与操作实践
需积分: 2 29 浏览量
更新于2024-08-04
收藏 17KB DOCX 举报
"mysql面试题.docx"
以下是对面试题中涉及的MySQL知识点的详细解释:
1. 开启MySQL服务:可以通过操作系统的服务管理工具(如Windows的服务管理器或Linux的systemctl)启动MySQL服务。
2. 检测端口是否运行:使用命令`netstat -an | grep :port`(将port替换为MySQL默认的3306端口)检查端口是否在监听。
3. 设置/修改密码:使用`ALTER USER 'username'@'localhost' IDENTIFIED BY 'newpassword';`命令。
4. 登陆MySQL数据库:通过命令`mysql -u username -p`,然后输入密码。
5. 查看当前数据库的字符集:使用`SHOW VARIABLES LIKE 'character_set_database';`。
6. 查看当前数据库版本:执行`SELECT VERSION();`。
7. 查看当前登录的用户:`SELECT USER();`。
8. 创建GBK字符集的数据库:`CREATE DATABASE oldboy CHARACTER SET gbk;`。
9. 创建用户并授权:`CREATE USER 'oldboy'@'localhost'; GRANT ALL PRIVILEGES ON oldboy.* TO 'oldboy'@'localhost';`。
10. 查看用户权限:`SHOW GRANTS FOR 'oldboy'@'localhost';`。
11. 查看当前数据库里的用户:`SELECT User FROM mysql.user;`。
12. 进入数据库:`USE oldboy;`。
13. 创建表:`CREATE TABLE test (id INT(4), name VARCHAR(16)) ENGINE=InnoDB DEFAULT CHARSET=gbk;`。
14. 查看建表语句:`SHOW CREATE TABLE test;`。
15. 插入数据:`INSERT INTO test (id, name) VALUES (1, 'oldboy');`。
16. 批量插入:`INSERT INTO test (id, name) VALUES (2, '老男孩'), (3, 'oldboyedu');`。
17. 查询:`SELECT * FROM test WHERE name = 'oldboy';`。
18. 更新数据:`UPDATE test SET name = 'oldgirl' WHERE id = 1;`。
19. 添加字段:`ALTER TABLE test ADD age TINYINT(2) BEFORE name;`。
20. 备份数据库:使用`mysqldump -u username -p oldboy > backup.sql`。
21. 删除数据:`DELETE FROM test;`,查看:`SELECT * FROM test;`。
22. 删除表和数据库:`DROP TABLE test;`,`DROP DATABASE oldboy;`,查看:`SHOW DATABASES;`。
23. 恢复数据:`RESTORE TABLE test FROM DUMPFILE backup.sql;`,`RESTORE DATABASE oldboy FROM DUMPFILE backup.sql;`。
24. 修改字符集:`ALTER DATABASE oldboy CHARACTER SET utf8;`。
25. 设置主键和索引:`ALTER TABLE test MODIFY id INT(4) PRIMARY KEY, ADD INDEX idx_name (name);`。
26. 添加字段:`ALTER TABLE test ADD shouji CHAR(11) AFTER name;`。
27. 插入数据:`INSERT INTO test (id, name, shouji) VALUES (4, 'user1', '12345678901'), (5, 'user2', '23456789012');`。
28. 创建索引:`ALTER TABLE test ADD INDEX idx_shouji (shouji(8));`。
29. 查看索引:`SHOW INDEX FROM test;`。
30. 删除索引:`ALTER TABLE test DROP INDEX idx_name, DROP INDEX idx_shouji;`。
31. 创建联合索引:`ALTER TABLE test ADD INDEX idx_name_shouji (name(6), shouji(8));`。
32. 查询记录:`SELECT * FROM test WHERE shouji LIKE '135%' AND name = 'oldboy';`。
33. 执行计划:`EXPLAIN SELECT * FROM test WHERE shouji LIKE '135%' AND name = 'oldboy';`。
34. 改变表引擎:`ALTER TABLE test ENGINE=MyISAM;`。
35. 回收权限:`REVOKE SELECT ON oldboy.* FROM 'oldboy'@'localhost';`。
36. 删除用户:`DROP USER 'oldboy'@'localhost';`。
37. 删除数据库:`DROP DATABASE oldboy;`。
38. 密码找回:通过`mysqladmin -u username -p password newpassword`重置密码。
MySQL运维基础知识面试问答题:
1. 关系型数据库概念:存储和管理数据的系统,基于关系理论,数据以表格形式存在,强调数据之间的关联性。
2. 典型产品:MySQL、Oracle、SQL Server、PostgreSQL等。特点包括ACID(原子性、一致性、隔离性和持久性)属性,易于理解和使用。应用场景:广泛应用于Web应用、企业信息系统等。
3. 解释数据库管理系统(DBMS)的基本概念:用于创建、维护和管理数据库的软件系统,提供数据的存储、检索、更新和删除等功能,确保数据的安全性和完整性。
2023-03-07 上传
2023-03-19 上传
2023-08-20 上传
2023-04-09 上传
2023-11-16 上传
2023-02-16 上传
2023-05-17 上传
2024-11-07 上传
半调子全栈
- 粉丝: 89
- 资源: 11
最新资源
- 探索数据转换实验平台在设备装置中的应用
- 使用git-log-to-tikz.py将Git日志转换为TIKZ图形
- 小栗子源码2.9.3版本发布
- 使用Tinder-Hack-Client实现Tinder API交互
- Android Studio新模板:个性化Material Design导航抽屉
- React API分页模块:数据获取与页面管理
- C语言实现顺序表的动态分配方法
- 光催化分解水产氢固溶体催化剂制备技术揭秘
- VS2013环境下tinyxml库的32位与64位编译指南
- 网易云歌词情感分析系统实现与架构
- React应用展示GitHub用户详细信息及项目分析
- LayUI2.1.6帮助文档API功能详解
- 全栈开发实现的chatgpt应用可打包小程序/H5/App
- C++实现顺序表的动态内存分配技术
- Java制作水果格斗游戏:策略与随机性的结合
- 基于若依框架的后台管理系统开发实例解析