## 使用命令連接
* 命令操作方式,在工作中使用的更多一些,所以要達到熟練的程度
* 打開終端,運行命令
~~~
mysql -uroot -p
回車后輸入密碼,當前設置的密碼為mysql
~~~
* 連接成功后如下圖

* 退出登錄
~~~
quit或exit
~~~
* 退出成功后如下圖

* 登錄成功后,輸入如下命令查看效果
~~~
查看版本:select version();
顯示當前時間:select now();
~~~
>[warning] 注意:在語句結尾要使用分號;
## 遠程連接
* 一般在公司開發中,可能會將數據庫統一搭建在一臺服務器上,所有開發人員共用一個數據庫,而不是在自己的電腦中配置一個數據庫
* 運行命令
`mysql -h(ip地址) -uroot -p`
* -h后面寫要連接的主機ip地址
* -u后面寫連接的用戶名
* -p回車后寫密碼
## 數據庫操作
* 創建數據庫
`create database 數據庫名 charset=utf8;`
* 刪除數據庫
`drop database 數據庫名;`
* 切換數據庫
`use 數據庫名;`
* 查看當前選擇的數據庫
`select database();`
## 表操作
* 查看當前數據庫中所有表
~~~
show tables;
~~~
* 創建表
* auto_increment表示自動增長
~~~
create table 表名(列及類型);
如:
create table students(
id int auto_increment primary key,
sname varchar(10) not null
);
~~~
* 修改表
~~~
alter table 表名 add|change|drop 列名 類型;
如:
alter table students add birthday datetime;
~~~
* 刪除表
~~~
drop table 表名;
~~~
* 查看表結構
~~~
desc 表名;
~~~
* 更改表名稱
~~~
rename table 原表名 to 新表名;
~~~
* 查看表的創建語句
~~~
show create table '表名';
~~~
## 數據操作
* 查詢
~~~
select * from 表名
~~~
* 增加
~~~
全列插入:insert into 表名 values(...)
缺省插入:insert into 表名(列1,...) values(值1,...)
同時插入多條數據:insert into 表名 values(...),(...)...;
或insert into 表名(列1,...) values(值1,...),(值1,...)...;
~~~
* 主鍵列是自動增長,但是在全列插入時需要占位,通常使用0,插入成功后以實際數據為準
* 修改
~~~
update 表名 set 列1=值1,... where 條件
~~~
* 刪除
~~~
delete from 表名 where 條件
~~~
* 邏輯刪除,本質就是修改操作update
~~~
alter table students add isdelete bit default 0;
如果需要刪除則
update students isdelete=1 where ...;
~~~
## 備份與恢復
**數據備份**
* 進入超級管理員
~~~
sudo -s
~~~
* 進入mysql庫目錄
~~~
cd /var/lib/mysql
~~~
* 運行mysqldump命令
~~~
mysqldump –uroot –p 數據庫名 > ~/Desktop/備份文件.sql;
按提示輸入mysql的密碼
~~~
**數據恢復**
* 連接mysqk,創建數據庫
* 退出連接,執行如下命令
~~~
mysql -uroot –p 數據庫名 < ~/Desktop/備份文件.sql
根據提示輸入mysql密碼
~~~
- mysql
- 1.創建庫和表
- 1.1.數據庫簡介
- 1.2.安裝管理
- 1.3.數據完整性
- 1.4.命令腳本操作
- 2.查詢
- 2.1.條件
- 2.2.聚合
- 2.3.分組
- 2.4.排序
- 2.5.分頁
- 3.高級
- 3.1.關系
- 3.2.連接
- 3.3.自關聯
- 3.4.子查詢
- 3.5.內置函數
- 3.6.視圖
- 3.7.事務
- 4.與python交互
- 4.1.交互類型
- 4.2.增改刪
- 4.3.查詢
- 4.4.封裝
- 4.5.用戶登錄
- Nosql簡介
- mongodb
- 1.基本操作
- 1.1.環境安裝
- 1.2.數據庫操作
- 1.3.集合操作
- 1.4.數據類型
- 1.5.數據操作
- 1.6.數據查詢
- 1.6.1.Limit與Skip
- 1.6.2.投影
- 1.6.3.排序
- 1.6.4.統計個數
- 1.6.5.消除重復
- 2.高級操作
- 2.1.聚合aggregate
- 2.1.1.$group
- 2.1.2.$match
- 2.1.3.$project
- 2.1.4.$sort
- 2.1.5.$limit,$skip
- 2.1.6.$unwind
- 2.2.安全
- 2.3.復制(副本集)
- 2.4.備份和恢復
- 2.5.與python交互
- redis
- 1.基本配置
- 2.數據操作
- 2.1.string
- 2.2.鍵命令
- 2.3.hash
- 2.4.list
- 2.5.set
- 2.6.zset
- 4.高級
- 4.1.發布訂閱
- 4.2.主從配置
- 5.與python交互
- 6.login登陸完善