1、數據庫的簡介html
什麼是數據庫?mysql
數據的倉庫,如:在atm的實例中咱們建立一個db目錄稱之爲數據庫linux
什麼是 MySQL、Oracle、SQLite、Access、MS SQL Server等 ?sql
他們是數據庫軟件,主要功能爲兩部分:一、講數據保存到內存或者文件。二、接受特定的命令對數據進行操做數據庫
什麼是SQL?windows
上述問題說過,數據庫要接受特定的命令,這個命令就是用SQL編寫,他是結構化查詢語言(Structured Query Language)的縮寫,一種專門與數據庫交互的語言。服務器
2、數據庫的安裝架構
windows版本socket
一、下載ide
MySQL Community Server 5.7.16 http://dev.mysql.com/downloads/mysql/
二、解壓
若是想要讓MySQL安裝在指定目錄,那麼就將解壓後的文件夾移動到指定目錄,如:C:\mysql-5.7.16-winx64
三、初始化
MySQL解壓後的 bin 目錄下有一大堆的可執行文件,執行以下命令初始化數據:
cd c:\mysql-5.7.16-winx64\bin mysqld --initialize-insecure
四、啓動MySQL服務
執行命令從而啓動MySQL服務
# 進入可執行文件目錄 cd c:\mysql-5.7.16-winx64\bin # 啓動MySQL服務 mysqld
五、啓動MySQL客戶端並鏈接MySQL服務
因爲初始化時使用的【mysqld --initialize-insecure】命令,其默認未給root帳戶設置密碼
# 進入可執行文件目錄 cd c:\mysql-5.7.16-winx64\bin # 鏈接MySQL服務器 mysql -u root -p # 提示請輸入密碼,直接回車
輸入回車,見下圖表示安裝成功:
、
到此爲止,MySQL服務端已經安裝成功而且客戶端已經能夠鏈接上,之後再操做MySQL時,只須要重複上述四、5步驟便可。可是,在四、5步驟中重複的進入可執行文件目錄比較繁瑣,如想往後操做簡便,能夠作以下操做。
添加環境變量
將MySQL可執行文件添加到環境變量中,從而執行執行命令便可
【右鍵計算機】--》【屬性】--》【高級系統設置】--》【高級】--》【環境變量】--》【在第二個內容框中找到 變量名爲Path 的一行,雙擊】 --> 【將MySQL的bin目錄路徑追加到變值值中,用 ; 分割】 如: C:\Program Files (x86)\Parallels\Parallels Tools\Applications;%SystemRoot%\system32;%SystemRoot%;%SystemRoot%\System32\Wbem;%SYSTEMROOT%\System32\WindowsPowerShell\v1.0\;C:\Python27;C:\Python35;C:\mysql-5.7.16-winx64\bin
如此一來,之後再啓動服務並鏈接時,僅需:
# 啓動MySQL服務,在終端輸入 mysqld # 鏈接MySQL服務,在終端輸入: mysql -u root -p
. 將MySQL服務製做成windows服務
上一步解決了一些問題,但不夠完全,由於在執行【mysqd】啓動MySQL服務器時,當前終端會被hang住,那麼作一下設置便可解決此問題:
# 製做MySQL的Windows服務,在終端執行此命令: "c:\mysql-5.7.16-winx64\bin\mysqld" --install # 移除MySQL的Windows服務,在終端執行此命令: "c:\mysql-5.7.16-winx64\bin\mysqld" --remove
註冊成服務以後,之後再啓動和關閉MySQL服務時,僅需執行以下命令:
# 啓動MySQL服務 net start mysql # 關閉MySQL服務 net stop mysql
linux版本
安裝
yum install mysql-server
啓動
mysql.server start
連接
鏈接: mysql -h host -u user -p 常見錯誤: ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2), it means that the MySQL server daemon (Unix) or service (Windows) is not running. 退出: QUIT 或者 Control+D
3、數據庫的操做
一、顯示數據庫
SHOW DATABASES;
默認數據庫:
mysql - 用戶權限相關數據
test - 用於用戶測試數據
information_schema - MySQL自己架構相關數據
二、建立數據庫
# utf-8 CREATE DATABASE 數據庫名稱 DEFAULT CHARSET utf8 COLLATE utf8_general_ci; # gbk CREATE DATABASE 數據庫名稱 DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;
三、使用數據庫
USE db_name;
四、用戶管理
建立用戶 create user '用戶名'@'IP地址' identified by '密碼'; 刪除用戶 drop user '用戶名'@'IP地址'; 修改用戶 rename user '用戶名'@'IP地址'; to '新用戶名'@'IP地址';; 修改密碼 set password for '用戶名'@'IP地址' = Password('新密碼') PS:用戶權限相關數據保存在mysql數據庫的user表中,因此也能夠直接對其進行操做(不建議)
五、受權管理
show grants for '用戶'@'IP地址' -- 查看權限 grant 權限 on 數據庫.表 to '用戶'@'IP地址' -- 受權 revoke 權限 on 數據庫.表 from '用戶'@'IP地址' -- 取消權限
注:flush privileges,將數據讀取到內存中,從而實現不重啓便可生效。
4、數據表的處理
一、建立表
二、刪除表
drop table 表名
三、清空表
delete from 表名 truncate table 表名
四、修改表
添加列:alter table 表名 add 列名 類型 刪除列:alter table 表名 drop column 列名 修改列: alter table 表名 modify column 列名 類型; -- 類型 alter table 表名 change 原列名 新列名 類型; -- 列名,類型 添加主鍵: alter table 表名 add primary key(列名); 刪除主鍵: alter table 表名 drop primary key; alter table 表名 modify 列名 int, drop primary key; 添加外鍵:alter table 從表 add constraint 外鍵名稱(形如:FK_從表_主表) foreign key 從表(外鍵字段) references 主表(主鍵字段); 刪除外鍵:alter table 表名 drop foreign key 外鍵名稱 修改默認值:ALTER TABLE testalter_tbl ALTER i SET DEFAULT 1000; 刪除默認值:ALTER TABLE testalter_tbl ALTER i DROP DEFAULT;
五、基本數據類型
MySQL的數據類型大體分爲:數值、時間和字符串
更多參考:
5、表內容操做
一、增
insert into 表 (列名,列名...) values (值,值,值...) insert into 表 (列名,列名...) values (值,值,值...),(值,值,值...) insert into 表 (列名,列名...) select (列名,列名...) from 表
二、刪
delete from 表 delete from 表 where id=1 and name='alex'
三、改
update 表 set name = 'alex' where id>1
四、查
select * from 表 select * from 表 where id > 1 select nid,name,gender as gg from 表 where id > 1
五、其餘
a、條件 select * from 表 where id > 1 and name != 'alex' and num = 12; select * from 表 where id between 5 and 16; select * from 表 where id in (11,22,33) select * from 表 where id not in (11,22,33) select * from 表 where id in (select nid from 表) b、通配符 select * from 表 where name like 'ale%' - ale開頭的全部(多個字符串) select * from 表 where name like 'ale_' - ale開頭的全部(一個字符) c、限制 select * from 表 limit 5; - 前5行 select * from 表 limit 4,5; - 從第4行開始的5行 select * from 表 limit 5 offset 4 - 從第4行開始的5行 d、排序 select * from 表 order by 列 asc - 根據 「列」 從小到大排列 select * from 表 order by 列 desc - 根據 「列」 從大到小排列 select * from 表 order by 列1 desc,列2 asc - 根據 「列1」 從大到小排列,若是相同則按列2從小到大排序 e、分組 select num from 表 group by num select num,nid from 表 group by num,nid select num,nid from 表 where nid > 10 group by num,nid order nid desc select num,nid,count(*),sum(score),max(score),min(score) from 表 group by num,nid select num from 表 group by num having max(id) > 10 特別的:group by 必須在where以後,order by以前 f、連表 無對應關係則不顯示 select A.num, A.name, B.name from A,B Where A.nid = B.nid 無對應關係則不顯示 select A.num, A.name, B.name from A inner join B on A.nid = B.nid A表全部顯示,若是B中無對應關係,則值爲null select A.num, A.name, B.name from A left join B on A.nid = B.nid B表全部顯示,若是B中無對應關係,則值爲null select A.num, A.name, B.name from A right join B on A.nid = B.nid g、組合 組合,自動處理重合 select nickname from A union select name from B 組合,不處理重合 select nickname from A union all select name from B
-轉載