2018-03-11 sql基礎(chǔ)

創(chuàng)建數(shù)據(jù)庫mysqladmin -u root -p create database_name

刪除數(shù)據(jù)庫mysqladmin -u root -p drop database_name

選擇數(shù)據(jù)庫use database_name

創(chuàng)建數(shù)據(jù)表CREATE TABLE table_name(column_name column_type);
create table test_tbl (
id int unsigned auto_increment,
title varchar(100) not null,
author varchar(40) not null,
sub_date date,
primary key(id)
)engine=InnoDB default charset=utf8;

查看表結(jié)構(gòu)DESC table_name;

刪除數(shù)據(jù)表DROP TABLE table_name;

插入數(shù)據(jù)INSERT INTO table_name (field1,field2,..) VALUES (value1,value2);

查詢數(shù)據(jù)select column_name1,column_name2 from table_name
[WHERE Clause] [LIMIT N] [OFFSET M]
where
SELECT field1, field2,...fieldN FROM table_name1, table_name2...
[WHERE condition1 [AND [OR]] condition2.....
字符串是不區(qū)分大小寫的,可用BINARY關(guān)鍵字設(shè)定區(qū)分大小寫

update
UPDATE table_name SET field1=new-value1, field2=new-value2
[WHERE Clause]

delete
DELETE FROM table_name
[WHERE Clause] 不指定where條件压真,則刪除整表

like
SELECT field1, field2,...fieldN
FROM table_name
WHERE field1 LIKE condition1 [AND [OR]] filed2 = '%somevalue'

union
SELECT expression1, expression2, ... expression_n
FROM tables
[WHERE conditions]
UNION [ALL | DISTINCT]
SELECT expression1, expression2, ... expression_n
FROM tables
[WHERE conditions];
DISTINCT: 可選追逮,刪除結(jié)果集中重復的數(shù)據(jù)噪径。默認情況下 UNION 操作符已經(jīng)刪除了重復數(shù)據(jù),所以 DISTINCT 修飾符對結(jié)果沒啥影響。ALL: 可選街佑,返回所有結(jié)果集似踱,包含重復數(shù)據(jù)。

order by
SELECT field1, field2,...fieldN table_name1, table_name2...
ORDER BY field1, [field2...] [ASC [DESC]]

group by
SELECT column_name, function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name;
函數(shù):COUNT, SUM, AVG,
eg.SELECT name, COUNT(*) FROM employee_tbl GROUP BY name;
mysql> SELECT name, SUM(singin) as singin_count FROM employee_tbl GROUP BY name WITH ROLLUP;
+--------+--------------+
| name | singin_count |
+--------+--------------+
| 小麗 | 2 |
| 小明 | 7 |
| 小王 | 7 |
| NULL | 16 |
+--------+--------------+
其中記錄 NULL 表示所有人的登錄次數(shù)墓臭。
我們可以使用 coalesce 來設(shè)置一個可以取代 NUll 的名稱蘸鲸,coalesce 語法:
select coalesce(a,b,c);
參數(shù)說明:如果a==null,則選擇b;如果b==null,則選擇c窿锉;如果a!=null,則選擇a酌摇;如果a b c 都為null ,則返回為null(沒意義)嗡载。
以下實例中如果名字為空我們使用總數(shù)代替:
mysql> SELECT coalesce(name, '總數(shù)'), SUM(singin) as singin_count FROM employee_tbl GROUP BY name WITH ROLLUP;
+--------------------------+--------------+
| coalesce(name, '總數(shù)') | singin_count |
+--------------------------+--------------+
| 小麗 | 2 |
| 小明 | 7 |
| 小王 | 7 |
| 總數(shù) | 16 |
+--------------------------+--------------+

join連接?
inner join獲取兩個表中字段匹配關(guān)系的記錄窑多。
left join獲取左表所有記錄,即使右表沒有對應匹配的記錄鼻疮。
right join用于獲取右表所有記錄怯伊,即使左表沒有對應匹配的記錄。
select a.,b. from a inner join b on a.id = b.parent_id 取交集
select a.,b. from a left join b on a.id = b.parent_id 以a中所有查b
select a.,b. from a right join b on a.id = b.parent_id 以b中所有查a
select a.,b. from a full join b on a.id = b.parent_id 取并集

NULL
IS NULL: 當列的值是 NULL,此運算符返回 true判沟。
IS NOT NULL: 當列的值不為 NULL, 運算符返回 true。
<=>: 比較操作符(不同于=運算符)崭篡,當比較的的兩個值為 NULL 時返回 true挪哄。
在 MySQL 中,NULL 值與任何其它值的比較(即使是 NULL)永遠返回 false琉闪,即 NULL = NULL 返回false 迹炼。

正則
SELECT name FROM person_tbl WHERE name REGEXP '^[aeiou]|ok$';

事務處理主要有兩種方法:
1、用 BEGIN, ROLLBACK, COMMIT來實現(xiàn)
BEGIN 開始一個事務
ROLLBACK 事務回滾
COMMIT 事務確認
2、直接用 SET 來改變 MySQL 的自動提交模式:
SET AUTOCOMMIT=0 禁止自動提交
SET AUTOCOMMIT=1 開啟自動提交

mysql> begin; # 開始事務
mysql> insert into runoob_transaction_test value(5);
mysql> insert into runoob_transaction_test value(6);
mysql> commit; # 提交事務
mysql> select * from runoob_transaction_test;
+------+
| id |
+------+
| 5 |
| 6 |
+------+

mysql> begin; # 開始事務
mysql> insert into runoob_transaction_test values(7);
mysql> rollback; # 回滾
mysql> select * from runoob_transaction_test; # 因為回滾所以數(shù)據(jù)沒有插入
+------+
| id |
+------+
| 5 |
| 6 |
+------+
$dbhost = 'localhost:3306'; // mysql服務器主機地址
$dbuser = 'root'; // mysql用戶名
$dbpass = '123456'; // mysql用戶名密碼
$conn = mysqli_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
die('連接失敗: ' . mysqli_error($conn));
}
// 設(shè)置編碼斯入,防止中文亂碼
mysqli_query($conn, "set names utf8");
mysqli_select_db( $conn, 'RUNOOB' );
mysqli_query($conn, "SET AUTOCOMMIT=0"); // 設(shè)置為不自動提交砂碉,因為MYSQL默認立即執(zhí)行
mysqli_begin_transaction($conn); // 開始事務定義

if(!mysqli_query($conn, "insert into runoob_transaction_test (id) values(8)"))
{
mysqli_query($conn, "ROLLBACK"); // 判斷當執(zhí)行失敗時回滾
}

if(!mysqli_query($conn, "insert into runoob_transaction_test (id) values(9)"))
{
mysqli_query($conn, "ROLLBACK"); // 判斷執(zhí)行失敗時回滾
}
mysqli_commit($conn); //執(zhí)行事務
mysqli_close($conn);

alter
修改表或字段,如果數(shù)據(jù)表中只剩余一個字段則無法使用DROP來刪除字段
ALTER TABLE testalter_tbl RENAME TO alter_tbl;//修改表名
ALTER TABLE testalter_tbl DROP id;//刪除字段id
ALTER TABLE testalter_tbl ADD i INT [FIRST | AFTER column_c];//添加字段i在首位或某字段之后刻两,默認添加至尾部
ALTER TABLE testalter_tbl MODIFY c CHAR(10);
ALTER TABLE testalter_tbl CHANGE i j BIGINT;
ALTER TABLE testalter_tbl MODIFY j BIGINT NOT NULL DEFAULT 100;//指定字段 j 為 NOT NULL 且默認值為100 增蹭。

索引
臨時表只在當前連接可見,當關(guān)閉連接時磅摹,Mysql會自動刪除表并釋放所有空間滋迈。
CREATE TEMPORARY TABLE SalesSummary (。户誓。饼灿。)

復制表
使用SHOW CREATE TABLE 命令獲取創(chuàng)建數(shù)據(jù)表(CREATE TABLE) 語句,該語句包含了原數(shù)據(jù)表的結(jié)構(gòu)帝美,索引等碍彭。再修改新表名稱,創(chuàng)建復制表悼潭。
或者庇忌,
CREATE TABLE targetTable LIKE sourceTable;
INSERT INTO targetTable SELECT * FROM sourceTable;

第一、只復制表結(jié)構(gòu)到新表
create table 新表 select * from 舊表 where 1=2
或者
create table 新表 like 舊表
第二女责、復制表結(jié)構(gòu)及數(shù)據(jù)到新表
create table新表 select * from 舊表

sql注入漆枚?

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市抵知,隨后出現(xiàn)的幾起案子墙基,更是在濱河造成了極大的恐慌,老刑警劉巖刷喜,帶你破解...
    沈念sama閱讀 217,826評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件残制,死亡現(xiàn)場離奇詭異,居然都是意外死亡掖疮,警方通過查閱死者的電腦和手機初茶,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來浊闪,“玉大人恼布,你說我怎么就攤上這事「楸觯” “怎么了折汞?”我有些...
    開封第一講書人閱讀 164,234評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長盖腿。 經(jīng)常有香客問我爽待,道長损同,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,562評論 1 293
  • 正文 為了忘掉前任鸟款,我火速辦了婚禮膏燃,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘何什。我一直安慰自己组哩,他們只是感情好,可當我...
    茶點故事閱讀 67,611評論 6 392
  • 文/花漫 我一把揭開白布富俄。 她就那樣靜靜地躺著禁炒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪霍比。 梳的紋絲不亂的頭發(fā)上幕袱,一...
    開封第一講書人閱讀 51,482評論 1 302
  • 那天,我揣著相機與錄音悠瞬,去河邊找鬼们豌。 笑死,一個胖子當著我的面吹牛浅妆,可吹牛的內(nèi)容都是我干的望迎。 我是一名探鬼主播,決...
    沈念sama閱讀 40,271評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼凌外,長吁一口氣:“原來是場噩夢啊……” “哼辩尊!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起康辑,我...
    開封第一講書人閱讀 39,166評論 0 276
  • 序言:老撾萬榮一對情侶失蹤摄欲,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后疮薇,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體胸墙,經(jīng)...
    沈念sama閱讀 45,608評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,814評論 3 336
  • 正文 我和宋清朗相戀三年按咒,在試婚紗的時候發(fā)現(xiàn)自己被綠了迟隅。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,926評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡励七,死狀恐怖智袭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情掠抬,我是刑警寧澤补履,帶...
    沈念sama閱讀 35,644評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站剿另,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜雨女,卻給世界環(huán)境...
    茶點故事閱讀 41,249評論 3 329
  • 文/蒙蒙 一谚攒、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧氛堕,春花似錦馏臭、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至锐想,卻和暖如春帮寻,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背赠摇。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評論 1 269
  • 我被黑心中介騙來泰國打工固逗, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人藕帜。 一個月前我還...
    沈念sama閱讀 48,063評論 3 370
  • 正文 我出身青樓烫罩,卻偏偏與公主長得像,于是被迫代替她去往敵國和親洽故。 傳聞我的和親對象是個殘疾皇子贝攒,可洞房花燭夜當晚...
    茶點故事閱讀 44,871評論 2 354

推薦閱讀更多精彩內(nèi)容