mysql+create+table+index_mysql------基础及常见SQL技巧
基礎
1.1 mysql表復制
復制表結構+復制表數據
mysql>create table t3 like t1;
mysql>insert into t3 select * from t1;
1.2 mysql 索引
1.ALTER TABLE用來創建普通索引,UNIQUE索引或PRIMARY KEY索引
ALTER TABLE table_name ADD INDEX index_name(column_list)
ALTER TABLE table_name ADD UNIQUE(column_list)
ALTER TABLE table_name ADD PRIMARY KEY(column_list)
2.create index
CREATE INDEX index_name ON table_name(column_list)
CREATE UNIQUE INDEX index_name ON table_name(column_list)
3.drop index
DROP INDEX index_name ON table_name
4.alter table table drop
ALTER TABLE table_name DROP INDEX index_name
ALTER TABLE table_name DROP PRIMARY KEY
1.3mysql視圖
mysql>create view v_t1 as select * from t1 where id>4 and id<11;
mysql> ? view //view視圖的幫助信息
ALTER VIEW
CREATE VIEW
DROP VIEW
mysql>show tables; //查看視圖
mysql>drop view v_t1; //刪除視圖v_t1
1.4mysql內置函數
字符串函數:
CONCAT(string2[,...]) //連接字符串
LCASE(string2) //轉換成小寫
UCASE(string2) //轉換成大寫
LENGTH(string) //string長度
LTRIM(string2) //去除前端空格
RTRIM(string2) //去除后端空格
REPEAT(string2,count) //重復count次
REPLACE(str,search_str,replace_str) //在str中用replace_str替換search_str
SUBSTRING(str,position[,length]) //從str的position開始,取length個字符
SPACE(count) //生成count個空格
數學函數:
BIN(decimal_number) //十進制轉二進制
CEILING(number2) //向上取整
FLOOR(number2) //向下取整
MAX(col) //取最大值,聚合時使用
MIN(col) //取最小值,聚合時使用
SORT(number2) //開平方
RAND() //返回0-1內的隨機值
日期函數:
CURDATE() //返回當前日期
CURTIME() //返回當前時間
NOW() //返回當前的日期時間
UNIX_TIMESTAMP(date) //返回當前date的UNIX時間戳
FROM_UNIXTIME() //返回UNIX時間戳的日期值
WEEK(date) //返回日期date為一年中的第幾周
YEAR(date) //返回日期date的年份
DATEDIFF(expr,expr2) //返回起始時間expr和結束時間expr2間天數
1.5mysql預處理語句
設置stmt1預處理,傳遞一個數據作為一個where判斷條件
mysql>prepare stmt1 from 'select * from t1 where id>?';
mysql>set @i=1; //設置一個變量
mysql>execute stmt1 using @i; //執行stmt1預處理
mysql>set@i=5; //設置@i為5
mysql>execute stmt1 using @i; //再次去執行stmt1
mysql>drop prepare stmt1: //如何刪除預處理stmt1
1.6mysql事務處理
mysql>set autocommit=0; //關閉自動提交功能
mysql>delete from t1 where id=11; //從表t1中刪除了一條記錄
mysql>savepoint p1; //此時做一個p1還原點
mysql>delete from t1 where id=10; //再次從表t1中刪除一條記錄
mysql>savepoint p2; //再次做一個p2還原點
mysql>rollback to p1; //此時恢復到p1還原點,即p2自動失效
mysql>rollback; //退回到最原始的還原點
1.7mysql存儲
創建一個存儲p1();
mysql>d //改變語句界定符
mysql>create procedure p1()
->begin
->set @i=0;
->while @i<10 do
->select @i;
->set @i=@i+1;
->end while;
->end;
->//
mysql>d;
mysql>call p1(); //執行存儲p1();
mysql>show procedurestatusG //查看procedure p1()的status信息
mysql>show create procedure p1G //查看procedure p1()的具體信息
1.8mysql觸發器 (用于增刪改)
創建一個名字為tg1的觸發器,當向t1表中插入數據時,就向t2表中插入一條數據
修改delimiter為//
mysql>d //
mysql>create trigger tg1 before insert on t1 for each row
>begin
>insert into t2(id) values(new.id);
>end//
準備兩個空表t1和t2
mysql>select * from t1;
mysql>select * from t2;
向t1表中插入多條數據:
mysql>insert into t1 values(1),(2),(3),(4);
mysql>create trigger t2 before delete on t1 for each row
-> begin
-> delete from t2 where id=old.id;
-> end//
如何制作刪除表t1后t2表中的記錄也會跟著刪除呢?
mysql>create trigger tg3 before delete on t1 for each row
>begin delete from t2 where id=old.id;
>end//
如何制作更改表t1后t2表也跟著修改呢?
mysql>create trigger tg4 before update on t1 for each row
>begin update t2 set id=new.id where id=old.id;
>end//
改回語句界定符為分號
mysql>d;
查看觸發器:
mysql>show triggers;
1.9重排auto_increment值
MYSQL數據庫自動增長的ID如何恢復
清空表的時候,不能用delete from tablename;
而是要用:truncate table tablename;
這樣auto_increment就恢復成1了
或者
清空內容后直接ALTER命令修改表:
alter table tablename auto_increment=1;
常見SQL技巧
2.1 正則表達式的使用 (? regexp)
使用正則表達式“$”和“[…]”進行匹配:
mysql>select name,email from t where email REGEXP “@163[.,]com$”
使用like方式查詢:
mysql>select name,email from t where email like “%@163.com” or email like “%@163,com”
2.2 巧用RAND()提取隨機行
MYSQL數據庫中有一個隨機函數rand()是獲取一個0-1之間的數,利用這個函數一起和order by能夠把數據隨機排序。
mysql>select * from stu order by rand();
下面是通過limit隨機抽取了3條數據樣本
mysql>select * from stu order by rand() limit3;
2.3 利用GROUP BY的WITH ROLLUP子句統計
使用group by 的 with rollup子句可以檢索出更多的分組聚合信息
對demo表按照cname、pname列分組對pname列進行聚合計算如下
同樣使用with rollup 關鍵字后,統計出更多的信息,如下(注意:with rollup不可以和order by同時使用)
2.4 利用BIT GROUP FUNCTIONS做統計
在使用group by語句時可以同時用使用bit_and、bit_or函數來完成統計工作。這兩個函數的作用主要是做數值之間的邏輯位運算
mysql>select id,bit_or(kind) from order_rab group by id;
對order_rab表中id分組時對kind做位與和或計算。
mysql>select id,bit_and(kind) from order_rab group by id;
2.5 使用外鍵需要注意的問題
創建外鍵的方式如下
mysql>create table temp(id int,name char(20),foreign key(id) references outTable(id) on delete cascade on update cascade);
注意:Innodb類型的表支持外鍵,myisam類型的表,雖然創建外鍵可以成功,但是不起作用,主要原因是不支持外鍵。
2.6 mysql中help的使用
在mysql中那么多的命令如何才能記得住是個問題,這里有一個特別好的獲得幫助的好方法,當然是在mysql》的提示下的操作:
? %
可以獲得所有的mysql>里的命令,這個是最多的,那么這里的東西如何去進一步獲得幫助呢?
?create
? opti%
因為記不住optimize的全稱,這個時候可以用%來替代
? reg%
獲得了記不住了的regexp用法
查看所有用? contents可以得到所有的幫助大綱,通過這個目錄再用?繼續往下細查。
總結
以上是生活随笔為你收集整理的mysql+create+table+index_mysql------基础及常见SQL技巧的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java学习笔记-良葛格_Java良葛格
- 下一篇: php mysql 大量读取_PHP使用