數(shù)據(jù)庫指的是以一定方式儲(chǔ)存在一起、能為多個(gè)用戶共享、具有盡可能小的冗余度、與應(yīng)用程序彼此獨(dú)立的數(shù)據(jù)集合。它具有整體性、共享性。數(shù)據(jù)庫軟件有著整體性和共享性的特點(diǎn)。下面就有小編為您帶來數(shù)據(jù)庫入門基礎(chǔ)知識(shí)的相關(guān)介紹。
1.創(chuàng)建數(shù)據(jù)庫
CREATE DATABASE database_name
2.刪除數(shù)據(jù)庫
DROP DATABASE database_name
3.選擇數(shù)據(jù)庫
USE database_name
4.數(shù)據(jù)類型
(1)數(shù)值類型
(2)日期和時(shí)間類型
(3)字符串類型
5.創(chuàng)建數(shù)據(jù)表
CREATE TABLE table_name (column_name column_type)
6.刪除數(shù)據(jù)表
DROP TABLE table_name
7.更新數(shù)據(jù)表信息
(1)添加表字段
ALTER TABLE table_name ADD new_column DATATYPE
使用FIRST關(guān)鍵字可以將新增列的順序調(diào)整至數(shù)據(jù)表的第一列
ALTER TABLE table_name ADD new_column DATATYPE FIRST
使用AFTER關(guān)鍵字可以將新增列調(diào)整至數(shù)據(jù)表的指定列之后
ALTER TABLE table_name ADD new_column DATATYPE AFTER old_column
(2)刪除表字段
ALTER TABLE table_name DROP old_column
(3)修改表字段類型
ALTER TABLE table_name MODIFY column_name NEW_DATATYPE
(4)修改字段名稱
ALTER TABLE table_name CHANGE old_column_name new_column_name DATATYPE
8.插入數(shù)據(jù)
INSERT INTO table_name (column1, column2,column3...columnN)
VALUES
(value1, value2, value3...valueN);
9.查詢數(shù)據(jù)
SELECT column1, column2, column3...columnN FROM table_name
(1)使用*可以替代字段名,SELECT語句會(huì)返回表的所有字段
例:SELECT * FROM table_name
(2)可以使用WHERE語句來包含任何條件
例:SELECT * FROM table_name WHERE column=1
(3)可以使用LIMIT屬性設(shè)定返回的記錄數(shù)
例:返回查詢結(jié)果的前三條記錄
SELECT * FROM table_name LIMIT 3
例:返回查詢結(jié)果的第三條記錄
SELECT * FROM table_name LIMIT 2,1 (2指的是第幾條數(shù)據(jù)(從0開始計(jì)數(shù)),1指的是從2開始返回幾條數(shù)據(jù))
(4)可以使用OFFSET指定開始查詢的偏移量,默認(rèn)情況下偏移量為0
例:SELECT * FROM table_name LIMIT 2 OFFSET 3 等于 SELECT * FROM table_name LIMIT 2,3
10.更新數(shù)據(jù)
UPDATE table_name SET column1=value1, column2=value2
WHERE condition
數(shù)據(jù)庫入門
11.刪除數(shù)據(jù)
DELECE FROM table_name
WHERE condition
12.LIKE子句
LIKE子句中使用%號(hào)來表示任意字符,其的效果類似正則表達(dá)式中的*,如果沒有使用%,那么LIKE的效果等價(jià)于=
SELECT * FROM table_name
WHERE column1 LIKE %condtion%
13.UNION
SELECT column1, column2, column3...columnN FROM table_a
[WHERE condition]
UNION [ALL | DISTINCT]
SELECT column1, column2, column3...columnN FROM table_b
[WHERE condition]
UNION的作用的連接兩個(gè)查詢結(jié)果集
DISTINCT的作用是對(duì)兩個(gè)結(jié)果集進(jìn)行去重處理,默認(rèn)情況下已經(jīng)是DISTINCT的結(jié)果了
ALL的作用的不對(duì)兩個(gè)結(jié)果集進(jìn)行去重處理
14.ORDER BY
SELECT * FROM table_name
ORDER BY column1 [ASC | DESC]
ASC:將結(jié)果集按column1升序排列,默認(rèn)情況下使用升序排序
DESC:將結(jié)果集按column1降序排列
15.GROUP BY
把數(shù)據(jù)按照指定列(可以是一列或者多列)進(jìn)行分組,通常和計(jì)算函數(shù)COUNT()還有SUM(),AVG()等求值函數(shù)一起使用
例:根據(jù)column1將數(shù)據(jù)進(jìn)行分組,并且統(tǒng)計(jì)每種數(shù)據(jù)的記錄數(shù)
SELECT column1, COUNT(*) FROM table_name
GROUP BY column1
WITH ROLLUP可以將GROUP BY的統(tǒng)計(jì)結(jié)果集基礎(chǔ)上再做相同的統(tǒng)計(jì)(SUM,AVG....)
例:假設(shè)有下面這樣一張表 name=姓名,website=網(wǎng)站,access_count=訪問記錄
name | website | access_count |
張三 | 百度 | 3 |
李四 | 新浪 | 5 |
王五 | 淘寶 | 4 |
張三 | 新浪 | 2 |
李四 | 百度 | 1 |
王五 | 搜狐 | 4 |
趙六 | 搜狐 | 5 |
執(zhí)行如下代碼:
SELECT name, SUM(access_count) FROM table_name
GROUP BY name WITH ROLLUP
得到:
name | SUM(access_count) |
張三 | 5 |
李四 | 6 |
王五 | 8 |
趙六 | 5 |
NULL | 24 |
16.INNER JOIN
INNER JOIN被稱為內(nèi)連接或者等值連接,獲取兩個(gè)表中字段匹配關(guān)系的記錄
例:SELECT table1.column1, table1.column1, table2.column3 FROM table1
INNER JOIN table2
ON condition
17.LEFT JOIN
LEFT JOIN被稱為左連接,獲取左邊所有記錄,右表沒有的記錄補(bǔ)為NULL
例:SELECT table1.column1, table1.column2, table2.column3 FROM table1
LEFT JOIN table2
ON condition
18.RIGHT JOIN
RIGHT JOIN被稱為右連接,獲取右邊所有數(shù)據(jù),左表沒有的記錄補(bǔ)為NULL
例:SELECT table1.column1, table2.column2, table2.column3 FROM table1
RIGHT JOIN table2
ON condition
數(shù)據(jù)庫管理系統(tǒng)是數(shù)據(jù)庫系統(tǒng)的核心,對(duì)數(shù)據(jù)庫的一切操作,如原始數(shù)據(jù)的裝入、檢索、更新、再組織等等,數(shù)據(jù)庫系統(tǒng)都是在DBMS的指揮、調(diào)度下進(jìn)行的,它是用戶與物理數(shù)據(jù)庫之間的橋梁,根據(jù)用戶的命令對(duì)數(shù)據(jù)庫執(zhí)行必要的操作。 以上就是小編為您介紹的數(shù)據(jù)庫入門基礎(chǔ)知識(shí),希望對(duì)您有所幫助。
[免責(zé)聲明]
文章標(biāo)題: 數(shù)據(jù)庫入門基礎(chǔ)知識(shí)
文章內(nèi)容為網(wǎng)站編輯整理發(fā)布,僅供學(xué)習(xí)與參考,不代表本網(wǎng)站贊同其觀點(diǎn)和對(duì)其真實(shí)性負(fù)責(zé)。如涉及作品內(nèi)容、版權(quán)和其它問題,請(qǐng)及時(shí)溝通。發(fā)送郵件至36dianping@36kr.com,我們會(huì)在3個(gè)工作日內(nèi)處理。