- 3.1 Connecting to and Disconnecting from the Server
获取超级用户root的密码
sudo grep 'temporary password' /var/log/mysqld.log
下面用用户名root和密码进行登录
shell> mysql -h host -u user -p
Enter password: ********
连接本地的mysql使用下面简洁的写法:
shell> mysql -u user -p
断开连接:
QUIT
可能碰到的问题:
问题一:
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock'
解答:
# MySQL服务器基本操作
(linux)
启动:service mysqld start
停止:service mysqld stop
重启:service mysqld restart
查看状态:service mysql status
查看状态:systemctl status mysql.service
(Mac OS X)
mysql start
mysql.server start # 1. 启动
mysql.server stop # 2. 停止
mysql.server restart # 3. 重启
// 未测试
注意在>5.5中使用的是mysql,旧版本使用的是mysqld
问题二:
MYSQL5.7:Access denied for user 'root'@'localhost' (using password:YES)
1.打开MySQL目录下的my.ini文件,在文件的最后添加一行“skip-grant-tables”,保存并关闭文件;
2.重启MySQL服务;
3.通过cmd行进入MySQL的bin目录,输入“mysql -u root -p”(不输入密码),回车即可进入数据库;
4.执行“use mysql;”,使用mysql数据库;
5.执行update mysql.user set authentication_string=password(‘123456’) where user='root' and Host = 'localhost';(修改root的密码,注意单引号和双引号);
6.打开MySQL目录下的my.ini文件,删除最后一行的“skip-grant-tables”,保存并关闭文件;
7.mysql> flush privileges;
8.mysql> quit;
9.在命令行中输入“mysql -u root -p 123456”,即可成功连接数据库。
- 3.2 Entering Queries
mysql> SELECT VERSION(), CURRENT_DATE;
mysql 不区分大小写
mysql> SELECT VERSION(), CURRENT_DATE; #OK
mysql> select version(), current_date; # OK
mysql> SeLeCt vErSiOn(), current_DATE; # OK
mysql> SELECT SIN(PI()/4), (4+1)*5;
mysql> SELECT VERSION(); SELECT NOW();
mysql> SELECT
-> USER()
-> ,
-> CURRENT_DATE;
mysql> SELECT
-> USER()
-> \c
- 3.3 Creating and Using a Database
mysql> SHOW DATABASES;
mysql> USE test
mysql> SELECT DATABASE(); // 显示当前所处的数据库
mysql> CREATE DATABASE menagerie;
连接数据库的时候就选定数据库
shell> mysql -h host -u user -p menagerie
Enter password: ********
mysql> SHOW TABLES;
mysql> CREATE TABLE pet (name VARCHAR(20), owner VARCHAR(20),
-> species VARCHAR(20), sex CHAR(1), birth DATE, death DATE);
SHOW TABLES; //简单信息
mysql> DESCRIBE pet; //单个表的详细信息
mysql> LOAD DATA LOCAL INFILE '/path/pet.txt' INTO TABLE pet; // 插入数据(从文本文档中插入)
如果文本文档是windows中建立的则需要这样使用
mysql> LOAD DATA LOCAL INFILE '/path/pet.txt' INTO TABLE pet
-> LINES TERMINATED BY '\r\n';
不通过文本文档插入
mysql> INSERT INTO pet
-> VALUES ('Puffball','Diane','hamster','f','1999-03-30',NULL);
# 从文档中检索信息
SELECT what_to_select
FROM which_table
WHERE conditions_to_satisfy;
#修改
1.Edit the file `pet.txt` to correct the error, then empty the table and reload it using delete and load data;
mysql> DELETE FROM pet;
mysql> LOAD DATA LOCAL INFILE '/path/pet.txt' INTO TABLE pet;
2.Fix only the erroneous record with an UPDATE statement:
mysql> UPDATE pet SET birth = '1989-08-31' WHERE name = 'Bowser';
例子:
menagerie数据库中的表pet
data:image/s3,"s3://crabby-images/000d0/000d0217c1035478c0d23f7d1514a9e8f8ea4b44" alt=""
data:image/s3,"s3://crabby-images/d59f5/d59f51d514800b4178e9e9c2f5d1eb42cf742028" alt=""
data:image/s3,"s3://crabby-images/697bc/697bca682e218b0b4bba809684d196ba32c6869a" alt=""
data:image/s3,"s3://crabby-images/da3e3/da3e3a0c7c872571a49c7f5d13784bc89f09f418" alt=""
data:image/s3,"s3://crabby-images/27341/27341192ba5f1ca2e19f38f2933f8a3fff6fc0ff" alt=""
data:image/s3,"s3://crabby-images/21588/21588fe83de4ce1db1c5cd2b08f25b1dcedbdd5a" alt=""
data:image/s3,"s3://crabby-images/eb957/eb95706329762303e42bc8ca5707ced0e9a40911" alt=""
data:image/s3,"s3://crabby-images/a97fa/a97fa1a0e4a45b642684c4f6027a8ebac1291a65" alt=""
data:image/s3,"s3://crabby-images/d03b7/d03b795147aa005f09341c21ec7d1524a522245d" alt=""
data:image/s3,"s3://crabby-images/c42fc/c42fcb251542b9df354812dff3f149cecbf237ac" alt=""
data:image/s3,"s3://crabby-images/aefd2/aefd200b4c69420057da124edeaaa09079ea4a17" alt=""
data:image/s3,"s3://crabby-images/b9e32/b9e323d9241d119e6cdc9c3597f9c2df082324ff" alt=""
data:image/s3,"s3://crabby-images/713cb/713cb517e06732a2e6badc3e1e2a6d77728e203d" alt=""
data:image/s3,"s3://crabby-images/3d416/3d416af50ddc19c1a2b7e0d4d61774ca35cf4dd7" alt=""
网友评论