創(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注入漆枚?