好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > MySQL數據庫常用操作技巧總結

MySQL數據庫常用操作技巧總結

熱門標簽:凱立德科技館地圖標注 西安400電話在哪里辦理 中科嘉智人工智能電銷機器人 哈爾濱crm外呼系統價格 電銷機器人好品牌門薩維l 銀川電銷外呼系統定制 甘孜電話機器人廠家 上海智能外呼系統需要多少錢 做地圖標注都需要什么工具

本文實例總結了MySQL數據庫常用操作技巧。分享給大家供大家參考,具體如下:

一、查詢不同表中同名字段(表連接查詢條件神器)

use information_schema;
select * from columns where column_name='字段名';

二、查詢記錄總數

SELECT SQL_CALC_FOUND_ROWS * FROM TABLE WHERE 1=1;

即可得出總數據行數

SET @RowCount=found_rows();

三、存儲過程數據查詢分頁

預定義變量:

/*錯誤代碼*/
SET @RetCode='1';
/*錯誤提示*/
SET @RetVal='1';
/*返回記錄行數*/
SET @RowCount='0';
/*頁碼*/
SET @PageCount='0';
/*每頁顯示數*/
SET @CurrentItem=0;
/*每頁顯示數*/
SET @PageSize=arg_page_size;
/*頁碼*/
SET @PageCurrent=arg_page_current;
SET @SqlExe='select * from table where 1=1';
入參:arg_page_size int,arg_page_current int
IF(@PageCurrent IS NOT NULL  @PageSize IS NOT NULL) THEN
SET @CurrentItem = (@PageCurrent-1)*@PageSize;
SET @SqlExe=CONCAT(@SqlExe,'LIMIT ', @PageSize,' OFFSET ', @CurrentItem);
ELSE
SET @SqlExe=CONCAT(@SqlExe,' ');
END IF;
prepare stmt from @SqlExe;
execute stmt;
deallocate prepare stmt;
IF(@RowCount IS NOT NULL  @RowCount != 0) THEN
IF(@PageSize is null)then
SET @PageSize= @RowCount;
END IF;
SET @PageCount = ceiling(@RowCount/@PageSize);
ELSE
SET @RowCount = 0;
SET @PageCount = 1;
END IF;

四、字符串相關操作

1、從左開始截取字符串

left(str, length)

說明:left(被截取字段,截取長度)

例:

select left(content,200)as abstract from my_content_t

2、從右開始截取字符串

right(str, length)

說明:right(被截取字段,截取長度)

例:

select right(content,200)as abstract from my_content_t

3、截取字符串

substring(str, pos)

substring(str, pos, length)

說明:

substring(被截取字段,從第幾位開始截取)

substring(被截取字段,從第幾位開始截取,截取長度)

例:

select substring(content,5)as abstract from my_content_t
select substring(content,5,200)as abstract from my_content_t

(注:如果位數是負數 如-5則是從后倒數位數,到字符串結束或截取的長度)

4、按關鍵字截取字符串

substring_index(str,delim,count)

說明:substring_index(被截取字段,關鍵字,關鍵字出現的次數)

例:

select substring_index("blog.csdn.net",".",2)as abstract from my_content_t

結果:

blog.csdn

(注:如果關鍵字出現的次數是負數 如-2 則是從后倒數,到字符串結束)

函數簡介:

SUBSTRING(str,pos) , SUBSTRING(str FROM pos) SUBSTRING(str,pos,len) , SUBSTRING(str FROM pos FOR len)

不帶有len 參數的格式從字符串str返回一個子字符串,起始于位置pos。帶有len參數的格式從字符串str返回一個長度同len字符相同的子字符串,起始于位置pos。 使用FROM的格式為標準SQL 語法。也可能對pos使用一個負值。假若這樣,則子字符串的位置起始于字符串結尾的pos字符,而不是字符串的開頭位置。在以下格式的函數中可以對pos使用一個負值。

MySQL字符串大小寫轉換

deMySQL 字符串大小寫轉化函數有兩對: lower(), uppper()lcase(), ucase()

mysql>select lower('DDD');
結果:ddd
mysql> select upper('ddd');
結果:DDD
mysql> select lcase('DDD');
結果:ddd
mysql> select ucase('ddd');
結果:DDD

通常情況下,我選擇 lower(), upper() 來轉換字符串大小寫,因為這和其他數據庫中函數相兼容。

五、時間獲取相關操作

declare _LastWeekStartTime date; -- 上周開始時間
declare _LastWeekEndTime date; -- 上周結束時間

-- 因系統為星期日為每星期第一天 所以需要減1

set @A = date_add(curdate(), interval -1 day);

-- 算出本周星期一的日期

set @B = subdate( @A,date_format(@A,'%w')-1);

-- 因系統為星期日為每星期第一天 所以需要 減2獲取上星期最后一天(上星期星期六)

set @C = date_add(@B, interval -2 day);
set _LastWeekStartTime = ( subdate( @C,date_format( @C,'%w')-1));
set _LastWeekEndTime = ( date_add(subdate( @C,date_format( @C,'%w')-1), interval 6 day));

-- 獲取當前日期是星期幾 1為周日2為周一 以此類推

SET @nowdate=(select DAYOFWEEK(NOW()));
SET @NowD=case @nowdate
when 1 then '星期日'
when 2 then '星期一'
when 3 then '星期二'
when 4 then '星期三'
when 5 then '星期四'
when 6 then '星期五'
when 7 then '星期六'
end;

-- 周日時間需要重新計算

if (DATE_FORMAT(CURDATE(),'%w')=0) then
SET @curmon=(SELECT SUBDATE(CURDATE(),DATE_FORMAT(CURDATE(),'%w')+6));
SET @cursun=(SELECT SUBDATE(CURDATE(),DATE_FORMAT(CURDATE(),'%w')));
else

-- 開始時間(周一)

SET @curmon=(SELECT SUBDATE(CURDATE(),DATE_FORMAT(CURDATE(),'%w')-1));

-- 結束時間(周日)

SET @cursun=(SELECT SUBDATE(CURDATE(),DATE_FORMAT(CURDATE(),'%w')-7));

六、排序技巧

CREATE TABLE test (
id INT PRIMARY KEY not null auto_increment,
val nvarchar (50) NOT NULL
);
INSERT INTO test(val) VALUES ('0');
INSERT INTO test(val) VALUES ('1');
INSERT INTO test(val) VALUES ('2');
INSERT INTO test(val) VALUES ('3');
SELECT * from test;
-- 根據 id為 2 0 1 3的優先級自定義排序
SELECT * FROM test ORDER BY instr('2013',id);
-- 原理樣例
SET @ORDBYD='2013';
SELECT '2',instr(@ORDBYD,'2') as `INDEX`
union
SELECT '0',instr(@ORDBYD,'0') as `INDEX`
union
SELECT '1',instr(@ORDBYD,'1') as `INDEX`
union
SELECT '3',instr(@ORDBYD,'3') as `INDEX`;

instr函數(摘自百度百科instr函數語法)

instr( string1, string2, start_position,nth_appearance )

string1:源字符串,要在此字符串中查找。
string2:要在string1中查找的字符串 。
start_position:代表string1 的哪個位置開始查找。此參數可選,如果省略默認為1. 字符串索引從1開始。如果此參數為正,從左到右開始檢索,如果此參數為負,從右到左檢索,返回要查找的字符串在源字符串中的開始索引。
nth_appearance:代表要查找第幾次出現的string2. 此參數可選,如果省略,默認為 1.如果為負數系統會報錯。

注意:

位置索引號從1開始。

如果String2在String1中沒有找到,instr函數返回0。

示例:

SELECT instr('syranmo','s') FROM dual; -- 返回 1
SELECT instr('syranmo','ra') FROM dual; -- 返回 3
SELECT instr('syran mo','at',1,2) FROM dual; -- 返回 0

更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數據庫鎖相關技巧匯總》及《MySQL常用函數大匯總》

希望本文所述對大家MySQL數據庫計有所幫助。

您可能感興趣的文章:
  • mysql 5.7.20常用下載、安裝和配置方法及簡單操作技巧(解壓版免安裝)
  • JavaWeb連接數據庫MySQL的操作技巧
  • 利用tcpdump對mysql進行抓包操作技巧
  • 30個mysql千萬級大數據SQL查詢優化技巧詳解
  • Mysql根據時間查詢日期的優化技巧
  • 提升MYSQL查詢效率的10個SQL語句優化技巧
  • MySQL快速對比數據技巧
  • MySQL使用的常見問題解決與應用技巧匯總
  • 5個保護MySQL數據倉庫的小技巧
  • 分享101個MySQL調試與優化技巧
  • MySql Sql 優化技巧分享
  • MySQL注入繞開過濾的技巧總結

標簽:安徽 那曲 安康 平頂山 浙江 山南 濮陽 四川

巨人網絡通訊聲明:本文標題《MySQL數據庫常用操作技巧總結》,本文關鍵詞  MySQL,數據庫,常用,操作,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL數據庫常用操作技巧總結》相關的同類信息!
  • 本頁收集關于MySQL數據庫常用操作技巧總結的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 小坏蛋用力快再深点| 噜噜噜噜噜视频在线观看| 亚洲一区电影在线观看| 荫蒂每天被三个男人添视频| 果冻传媒啪啪A片Vt88| 久久久久麻豆V国产精华液好用吗| 欧美15一18sex性HD1| 妇女主任的婬乱生活电影| 免费人成网站尤物在线观看| 在线免费毛片| 韩国福利一区| 麻豆久久婬片AA片在線觀看| 1819高清欧美xx| 揉胸插下面大尺度视频大全| 日本一級片黃色一級片尖叫声| 国产精品无码久久久久久网站| 被主人尿在身体里调教| 国产一级婬片A片A片精品户外| 亚洲综合导航| 欧洲女人性开放视频在线激情| japanese色系国产在线高清| 宝贝夹好上课(H| 久久AⅤ天堂Av无码AV泽村| 久草黑丝| 91免费视| JUX-925被中出的人妻| 老丈的又硬又粗| 午夜网站免费版在线观看| Japanese五十路熟妇HD| free性欧美hd粗暴| 爽好大快深一点| 一女多男np肉辣文小说| 欧美酷刑捆绑bdsmfoot| 国产激情一级毛片久久| 看强二次元人物免费动漫全部| 边吃奶边挵进去呻吟视频| 中文字幕精品无码亚洲字幕一区| 牛鞭伸入妇女下身| 特黄Av一级AAA片日本取精| 99国产精品人妻一区二区三区四| av拍摄灌满H|