我們知道從 MySQL 表中使用 SQL SELECT 語(yǔ)句來讀取數(shù)據(jù)。
創(chuàng)新互聯(lián)公司專注于革吉企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站開發(fā),商城開發(fā)。革吉網(wǎng)站建設(shè)公司,為革吉等地區(qū)提供建站服務(wù)。全流程定制設(shè)計(jì),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)
如果我們需要對(duì)讀取的數(shù)據(jù)進(jìn)行排序,我們就可以使用 MySQL 的 ORDER BY 子句來設(shè)定你想按哪個(gè)字段哪種方式來進(jìn)行排序,再返回搜索結(jié)果。
具體語(yǔ)法參考:
以下是 SQL SELECT 語(yǔ)句使用 ORDER BY 子句將查詢數(shù)據(jù)排序后再返回?cái)?shù)據(jù):
from 樹懶學(xué)堂 - 一站式數(shù)據(jù)知識(shí)平臺(tái)
你可以使用任何字段來作為排序的條件,從而返回排序后的查詢結(jié)果。
你可以設(shè)定多個(gè)字段來排序。
你可以使用 ASC 或 DESC 關(guān)鍵字來設(shè)置查詢結(jié)果是按升序或降序排列。 默認(rèn)情況下,它是按升序排列。
你可以添加 WHERE…LIKE 子句來設(shè)置條件。
所以,樓主所問的問題答案應(yīng)該為:select ... from ... order by ID desc limit(0,5)
呵呵,變通下即可,如:
select * from table where id in (select top 10 id from table)
以每24小時(shí)作為一份時(shí)間(而非自然日),根據(jù)用戶的配置有兩種工作模式:帶狀模式中,用戶僅定義開始日期時(shí),從開始日期(含)開始,每份時(shí)間1個(gè)分片地?zé)o限增加下去;環(huán)狀模式中,用戶定義了開始日期和結(jié)束日期時(shí),以結(jié)束日期(含)和開始日期(含)之間的時(shí)間份數(shù)作為分片總數(shù)(分片數(shù)量固定),以類似取模的方式路由到這些分片里。
1. DBLE 啟動(dòng)時(shí),讀取用戶在 rule.xml 配置的 sBeginDate 來確定起始時(shí)間
2. 讀取用戶在 rule.xml 配置的 sPartionDay 來確定每個(gè) MySQL 分片承載多少天內(nèi)的數(shù)據(jù)
3. 讀取用戶在 rule.xml 配置的 dateFormat 來確定分片索引的日期格式
4. 在 DBLE 的運(yùn)行過程中,用戶訪問使用這個(gè)算法的表時(shí),WHERE 子句中的分片索引值(字符串),會(huì)被提取出來嘗試轉(zhuǎn)換成 Java 內(nèi)部的時(shí)間類型
5. 然后求分片索引值與起始時(shí)間的差,除以 MySQL 分片承載的天數(shù),確定所屬分片
1. DBLE 啟動(dòng)時(shí),讀取用戶在 rule.xml 配置的起始時(shí)間 sBeginDate、終止時(shí)間 sEndDate 和每個(gè) MySQL 分片承載多少天數(shù)據(jù) sPartionDay
2. 根據(jù)用戶設(shè)置,建立起以 sBeginDate 開始,每 sPartionDay 天一個(gè)分片,直到 sEndDate 為止的一個(gè)環(huán),把分片串聯(lián)串聯(lián)起來
3. 讀取用戶在 rule.xml 配置的 defaultNode
4. 在 DBLE 的運(yùn)行過程中,用戶訪問使用這個(gè)算法的表時(shí),WHERE 子句中的分片索引值(字符串),會(huì)被提取出來嘗試轉(zhuǎn)換成 Java 內(nèi)部的日期類型
5. 然后求分片索引值與起始日期的差:如果分片索引值不早于 sBeginDate(哪怕晚于 sEndDate),就以 MySQL 分片承載的天數(shù)為模數(shù),對(duì)分片索引值求模得到所屬分片;如果分片索引值早于 sBeginDate,就會(huì)被放到 defaultNode 分片上
與MyCat的類似分片算法對(duì)比
中間件
DBLE
MyCat
分片算法種類 date 分區(qū)算法 按日期(天)分片
兩種中間件的取模范圍分片算法使用上無差別
開發(fā)注意點(diǎn)
【分片索引】1. 必須是字符串,而且 java.text.SimpleDateFormat 能基于用戶指定的 dateFormat 來轉(zhuǎn)換成 java.util.Date
【分片索引】2. 提供帶狀模式和環(huán)狀模式兩種模式
【分片索引】3. 帶狀模式以 sBeginDate(含)起,以 86400000 毫秒(24 小時(shí)整)為一份,每 sPartionDay 份為一個(gè)分片,理論上分片數(shù)量可以無限增長(zhǎng),但是出現(xiàn) sBeginDate 之前的數(shù)據(jù)而且沒有設(shè)定 defaultNode 的話,會(huì)路由失?。ㄈ绻?defaultNode,則路由至 defaultNode)
【分片索引】4. 環(huán)狀模式以 86400000 毫秒(24 小時(shí)整)為一份,每 sPartionDay 份為一個(gè)分片,以 sBeginDate(含)到 sEndDate(含)的時(shí)間長(zhǎng)度除以單個(gè)分片長(zhǎng)度得到恒定的分片數(shù)量,但是出現(xiàn) sBeginDate 之前的數(shù)據(jù)而且沒有設(shè)定 defaultNode 的話,會(huì)路由失敗(如果有 defaultNode,則路由至 defaultNode)
【分片索引】5. 無論哪種模式,分片索引字段的格式化字符串 dateFormat 由用戶指定
【分片索引】6. 無論哪種模式,劃分不是以日歷時(shí)間為準(zhǔn),無法對(duì)應(yīng)自然月和自然年,且會(huì)受閏秒問題影響
運(yùn)維注意點(diǎn)
【擴(kuò)容】1. 帶狀模式中,隨著 sBeginDate 之后的數(shù)據(jù)出現(xiàn),分片數(shù)量的增加無需再平衡
【擴(kuò)容】2. 帶狀模式?jīng)]有自動(dòng)增添分片的能力,需要運(yùn)維手工提前增加分片;如果路由策略計(jì)算出的分片并不存在時(shí),會(huì)導(dǎo)致失敗
【擴(kuò)容】3. 環(huán)狀模式中,如果新舊 [sBeginDate,sEndDate] 之間有重疊,需要進(jìn)行部分?jǐn)?shù)據(jù)遷移;如果新舊 [sBeginDate,sEndDate] 之間沒有重疊,需要數(shù)據(jù)再平衡
配置注意點(diǎn)
【配置項(xiàng)】1. 在 rule.xml 中,可配置項(xiàng)為 propertyname="sBeginDate" 、 propertyname="sPartionDay" 、 propertyname="dateFormat" 、 propertyname="sEndDate" 和 propertyname="defaultNode"
【配置項(xiàng)】2.在 rule.xml 中配置 propertyname="dateFormat",符合 java.text.SimpleDateFormat 規(guī)范的字符串,用于告知 DBLE 如何解析sBeginDate和sEndDate
【配置項(xiàng)】3.在 rule.xml 中配置 propertyname="sBeginDate",必須是符合 dateFormat 的日期字符串
【配置項(xiàng)】4.在 rule.xml 中配置 propertyname="sEndDate",必須是符合 dateFormat 的日期字符串;配置了該項(xiàng)使用的是環(huán)狀模式,若沒有配置該項(xiàng)則使用的是帶狀模式
【配置項(xiàng)】5.在 rule.xml 中配置 propertyname="sPartionDay",非負(fù)整數(shù),該分片策略以 86400000 毫秒(24 小時(shí)整)作為一份,而 sPartionDay 告訴 DBLE 把每多少份放在同一個(gè)分片
【配置項(xiàng)】6.在 rule.xml 中配置 propertyname="defaultNode" 標(biāo)簽,非必須配置項(xiàng),不配置該項(xiàng)的話,用戶的分片索引值沒落在 mapFile 定義
mysqldump備份還原和mysqldump導(dǎo)入導(dǎo)出語(yǔ)句大全詳解
mysqldump備份:
mysqldump -u用戶名 -p密碼 -h主機(jī)數(shù)據(jù)庫(kù) a -w "sql條件" --lock-all-tables 路徑
案例:
mysqldump -uroot -p1234 -hlocalhost db1 a -w "id in (select id from b)" --lock-all-tables c:\aa.txt
mysqldump還原:
mysqldump -u用戶名 -p密碼 -h主機(jī)數(shù)據(jù)庫(kù)路徑
案例:
mysql -uroot -p1234 db1 c:\aa.txt
mysqldump按條件導(dǎo)出:
mysqldump -u用戶名 -p密碼 -h主機(jī)數(shù)據(jù)庫(kù) a --where "條件語(yǔ)句" --no-建表路徑
mysqldump -uroot -p1234 dbname a --where "tag='88'" --no-create-info c:\a.sql
mysqldump按導(dǎo)入:
mysqldump -u用戶名 -p密碼 -h主機(jī)數(shù)據(jù)庫(kù)路徑
案例:
mysql -uroot -p1234 db1 c:\a.txt
mysqldump導(dǎo)出表:
mysqldump -u用戶名 -p密碼 -h主機(jī)數(shù)據(jù)庫(kù)表
案例:
mysqldump -uroot -p sqlhk9 a --no-data
講一下 mysqldump 的一些主要參數(shù)
--compatible=name
它告訴 mysqldump,導(dǎo)出的數(shù)據(jù)將和哪種數(shù)據(jù)庫(kù)或哪個(gè)舊版本的 MySQL 服務(wù)器相兼容。值可以為 ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options 等,要使用幾個(gè)值,用逗號(hào)將它們隔開。當(dāng)然了,它并不保證能完全兼容,而是盡量兼容。
--complete-insert,-c
導(dǎo)出的數(shù)據(jù)采用包含字段名的完整 INSERT 方式,也就是把所有的值都寫在一行。這么做能提高插入效率,但是可能會(huì)受到 max_allowed_packet 參數(shù)的影響而導(dǎo)致插入失敗。因此,需要謹(jǐn)慎使用該參數(shù),至少我不推薦。
--default-character-set=charset
指定導(dǎo)出數(shù)據(jù)時(shí)采用何種字符集,如果數(shù)據(jù)表不是采用默認(rèn)的 latin1 字符集的話,那么導(dǎo)出時(shí)必須指定該選項(xiàng),否則再次導(dǎo)入數(shù)據(jù)后將產(chǎn)生亂碼問題。
--disable-keys
告訴 mysqldump 在 INSERT 語(yǔ)句的開頭和結(jié)尾增加 /*!40000 ALTER TABLE table DISABLE KEYS */; 和 /*!40000 ALTER TABLE table ENABLE KEYS */; 語(yǔ)句,這能大大提高插入語(yǔ)句的速度,因?yàn)樗窃诓迦胪晁袛?shù)據(jù)后才重建索引的。該選項(xiàng)只適合 MyISAM 表。
--extended-insert = true|false
默認(rèn)情況下,mysqldump 開啟 --complete-insert 模式,因此不想用它的的話,就使用本選項(xiàng),設(shè)定它的值為 false 即可。
--hex-blob
使用十六進(jìn)制格式導(dǎo)出二進(jìn)制字符串字段。如果有二進(jìn)制數(shù)據(jù)就必須使用本選項(xiàng)。影響到的字段類型有 BINARY、VARBINARY、BLOB。
--lock-all-tables,-x
在開始導(dǎo)出之前,提交請(qǐng)求鎖定所有數(shù)據(jù)庫(kù)中的所有表,以保證數(shù)據(jù)的一致性。這是一個(gè)全局讀鎖,并且自動(dòng)關(guān)閉 --single-transaction 和 --lock-tables 選項(xiàng)。
--lock-tables
它和 --lock-all-tables 類似,不過是鎖定當(dāng)前導(dǎo)出的數(shù)據(jù)表,而不是一下子鎖定全部庫(kù)下的表。本選項(xiàng)只適用于 MyISAM 表,如果是 Innodb 表可以用 --single-transaction 選項(xiàng)。
--no-create-info,-t
只導(dǎo)出數(shù)據(jù),而不添加 CREATE TABLE 語(yǔ)句。
--no-data,-d
不導(dǎo)出任何數(shù)據(jù),只導(dǎo)出數(shù)據(jù)庫(kù)表結(jié)構(gòu)。
--opt
這只是一個(gè)快捷選項(xiàng),等同于同時(shí)添加 --add-drop-tables --add-locking --create-option --disable-keys --extended-insert --lock-tables --quick --set-charset 選項(xiàng)。本選項(xiàng)能讓 mysqldump 很快的導(dǎo)出數(shù)據(jù),并且導(dǎo)出的數(shù)據(jù)能很快導(dǎo)回。該選項(xiàng)默認(rèn)開啟,但可以用 --skip-opt 禁用。注意,如果運(yùn)行 mysqldump 沒有指定 --quick 或 --opt 選項(xiàng),則會(huì)將整個(gè)結(jié)果集放在內(nèi)存中。如果導(dǎo)出大數(shù)據(jù)庫(kù)的話可能會(huì)出現(xiàn)問題。
--quick,-q
該選項(xiàng)在導(dǎo)出大表時(shí)很有用,它強(qiáng)制 mysqldump 從服務(wù)器查詢?nèi)〉糜涗浿苯虞敵龆皇侨〉盟杏涗浐髮⑺鼈兙彺娴絻?nèi)存中。
--routines,-R
導(dǎo)出存儲(chǔ)過程以及自定義函數(shù)。
--single-transaction
該選項(xiàng)在導(dǎo)出數(shù)據(jù)之前提交一個(gè) BEGIN SQL語(yǔ)句,BEGIN 不會(huì)阻塞任何應(yīng)用程序且能保證導(dǎo)出時(shí)數(shù)據(jù)庫(kù)的一致性狀態(tài)。它只適用于事務(wù)表,例如 InnoDB 和 BDB。
本選項(xiàng)和 --lock-tables 選項(xiàng)是互斥的,因?yàn)?LOCK TABLES 會(huì)使任何掛起的事務(wù)隱含提交。
要想導(dǎo)出大表的話,應(yīng)結(jié)合使用 --quick 選項(xiàng)。
--triggers
同時(shí)導(dǎo)出觸發(fā)器。該選項(xiàng)默認(rèn)啟用,用 --skip-triggers 禁用它。
其他參數(shù)詳情請(qǐng)參考手冊(cè),我通常使用以下 SQL 來備份 MyISAM 表:
/usr/local/mysql/bin/mysqldump -uyejr -pyejr "
--default-character-set=utf8 --opt --extended-insert=false "
--triggers -R --hex-blob -x db_name db_name.sql
使用以下 SQL 來備份 Innodb 表:
/usr/local/mysql/bin/mysqldump -uyejr -pyejr "
--default-character-set=utf8 --opt --extended-insert=false "
--triggers -R --hex-blob --single-transaction db_name db_name.sql
另外,如果想要實(shí)現(xiàn)在線備份,還可以使用 --master-data 參數(shù)來實(shí)現(xiàn),如下:
/usr/local/mysql/bin/mysqldump -uyejr -pyejr "
--default-character-set=utf8 --opt --master-data=1 "
--single-transaction --flush-logs db_name db_name.sql
它只是在一開始的瞬間請(qǐng)求鎖表,然后就刷新binlog了,而后在導(dǎo)出的文件中加入CHANGE MASTER 語(yǔ)句來指定當(dāng)前備份的binlog位置,如果要把這個(gè)文件恢復(fù)到slave里去,就可以采用這種方法來做。
1.2 還原
用 mysqldump 備份出來的文件是一個(gè)可以直接倒入的 SQL 腳本,有兩種方法可以將數(shù)據(jù)導(dǎo)入。
直接用 mysql 客戶端
例如:
/usr/local/mysql/bin/mysql -uyejr -pyejr db_name db_name.sql
用 SOURCE 語(yǔ)法(實(shí)驗(yàn)不成功?。。。?/p>
其實(shí)這不是標(biāo)準(zhǔn)的 SQL 語(yǔ)法,而是 mysql 客戶端提供的功能,例如:
SOURCE /tmp/db_name.sql;
這里需要指定文件的絕對(duì)路徑,并且必須是 mysqld 運(yùn)行用戶(例如 nobody)有權(quán)限讀取的文件。
當(dāng)前文章:mysqlsql怎么寫 如何寫sql
網(wǎng)頁(yè)URL:http://jinyejixie.com/article18/doohpgp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、自適應(yīng)網(wǎng)站、移動(dòng)網(wǎng)站建設(shè)、外貿(mào)建站、關(guān)鍵詞優(yōu)化、用戶體驗(yàn)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)