字符串比較大小不是比較長短
創(chuàng)新互聯(lián)基于成都重慶香港及美國等地區(qū)分布式IDC機房數(shù)據(jù)中心構(gòu)建的電信大帶寬,聯(lián)通大帶寬,移動大帶寬,多線BGP大帶寬租用,是為眾多客戶提供專業(yè)服務(wù)器托管報價,主機托管價格性價比高,為金融證券行業(yè)服務(wù)器托管雅安,ai人工智能服務(wù)器托管提供bgp線路100M獨享,G口帶寬及機柜租用的專業(yè)成都idc公司。
從第一個字符開始比較,相同相等,遇到不同就比較出來了abc,根據(jù)ascii碼比較的
abcdabcde
我的答案是純手打的,請認(rèn)真看,不要浪費我的表情哦~
如果以字符串存儲,格式就是 年月日(20120101等于2012-01-01)的話
首先把 日期字符串 轉(zhuǎn)換成 合格的日期
concat_ws(連接符號,字符串1,字符串2...)
第一步代碼:
SELECT
CONCAT_WS('-',
SUBSTRING('20120101',1,4),
SUBSTRING('20120101',5,2),
SUBSTRING('20120101',7,2) ) AS 開始日期 ,
CONCAT_WS('-',
SUBSTRING('20120608',1,4),
SUBSTRING('20120608',5,2),
SUBSTRING('20120608',7,2) ) AS 結(jié)束日期 ;
------------------------------------------------------------
第二步,將日期使用日期運算函數(shù)進行相減:
TIMESTAMPDIFF(返回結(jié)果,日期1,日期2)
最終代碼:
SELECT
CONCAT_WS('-',
SUBSTRING('20120101',1,4),
SUBSTRING('20120101',5,2),
SUBSTRING('20120101',7,2) ) AS 開始日期 ,
CONCAT_WS('-',
SUBSTRING('20120608',1,4),
SUBSTRING('20120608',5,2),
SUBSTRING('20120608',7,2) ) AS 結(jié)束日期 ,
TIMESTAMPDIFF(
DAY,
CONCAT_WS('-',
SUBSTRING('20120101',1,4),
SUBSTRING('20120101',5,2),
SUBSTRING('20120101',7,2) ) ,
CONCAT_WS('-',
SUBSTRING('20120608',1,4),
SUBSTRING('20120608',5,2),
SUBSTRING('20120608',7,2) )
) AS 相差天數(shù)
;
-------------------------------------------------------------------------------------
不好意思,看錯題目,我以為你是要運算。如果是比較,就先把日期轉(zhuǎn)換為時間戳進行比較是這樣:
unix_timestamp(日期)
SELECT
unix_timestamp(
CONCAT_WS('-',
SUBSTRING('20120101',1,4),
SUBSTRING('20120101',5,2),
SUBSTRING('20120101',7,2) )
) AS 開始日期,
unix_timestamp(
CONCAT_WS('-',
SUBSTRING('20120608',1,4),
SUBSTRING('20120608',5,2),
SUBSTRING('20120608',7,2) )
) AS 開始結(jié)束;
--------------------------------------------------------------------------
直接判斷即可
新建一個數(shù)據(jù)庫來驗證:
CREATE DATABASE test5_4_17
DEFAULT CHARACTER SET utf8
DEFAULT COLLATE UTF8_BIN;
#新建一個test_4_17 使用utf8字符串
USE test5_4_17;
#打開數(shù)據(jù)庫
CREATE TABLE test(
id INT PRIMARY KEY NOT NULL AUTO_INCREMENT,
date_v VARCHAR(30) NOT NULL
);
INSERT INTO test VALUES(NULL,'20110303');
INSERT INTO test VALUES(NULL,'20120303');
INSERT INTO test VALUES(NULL,'20120304');
INSERT INTO test VALUES(NULL,'20130303');
SELECT * FROM test; #查看數(shù)據(jù)有了
SELECT * FROM
test
WHERE
UNIX_TIMESTAMP(date_v) =
unix_timestamp(
CONCAT_WS('-',
SUBSTRING('20120101',1,4),
SUBSTRING('20120101',5,2),
SUBSTRING('20120101',7,2) )
)
AND
UNIX_TIMESTAMP(date_v) =
unix_timestamp(
CONCAT_WS('-',
SUBSTRING('20120608',1,4),
SUBSTRING('20120608',5,2),
SUBSTRING('20120608',7,2) )
)
結(jié)果是
20120303
20120304
-----------------------------------------------------------------------------------------
參數(shù)中的 日期字符串 可以換成 字段名
問題:
返回結(jié)果錯誤;
明明沒有' '的行,居然匹配一堆數(shù)據(jù);
對比發(fā)現(xiàn)返回的都是''匹配的行
驗證:
有趣的是,
google答案:
這個失敗的原因在這里的文檔 中解釋:
CHAR和VARCHAR列中的值按照排序和比較 到分配給列的字符集整理。
所有MySQL串聯(lián)都是類型的PADSPACE.這意味著所有CHAR, 將MySQL中的varchar和TEXT值進行比較,而不考慮任何內(nèi)容 在這種情況下,“比較”不包括 像pattern-matching運算符,尾隨空間是 重要。
解決這個問題的一種方法是將其轉(zhuǎn)換為BINARY
您還可以使用LIKE: