MySQL面试必备:基础命令与操作实践

需积分: 2 1 下载量 12 浏览量 更新于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)的基本概念:用于创建、维护和管理数据库的软件系统,提供数据的存储、检索、更新和删除等功能,确保数据的安全性和完整性。