主頁 > 移動端開發 > sql基礎語法,非常全建議收藏(東方逐夢)

sql基礎語法,非常全建議收藏(東方逐夢)

2020-11-15 22:31:56 移動端開發

sql基礎教程

sql教程

什么是sql?
  • SQL 指結構化查詢語言
  • SQL 使我們有能力訪問資料庫
  • SQL 是一種 ANSI 的標準計算機語言
sql可以做什么
  • SQL 面向資料庫執行查詢
  • SQL 可從資料庫取回資料
  • SQL 可在資料庫中插入新的記錄
  • SQL 可更新資料庫中的資料
  • SQL 可從資料庫洗掉記錄
  • SQL 可創建新資料庫
  • SQL 可在資料庫中創建新表
  • SQL 可在資料庫中創建存盤程序
  • SQL 可在資料庫中創建視圖
  • SQL 可以設定表、存盤程序和視圖的權限
SQL 是一種標準 - 但是…
  • SQL 是一門 ANSI 的標準計算機語言,用來訪問和操作資料庫系統,SQL 陳述句用于取回和更新資料庫中的資料,SQL 可與資料庫程式協同作業,比如 MS Access、DB2、Informix、MS SQL Server、Oracle、Sybase 以及其他資料庫系統,

    不幸地是,存在著很多不同版本的 SQL 語言,但是為了與 ANSI 標準相兼容,它們必須以相似的方式共同地來支持一些主要的關鍵詞(比如 SELECT、UPDATE、DELETE、INSERT、WHERE 等等),

    **注釋:**除了 SQL 標準之外,大部分 SQL 資料庫程式都擁有它們自己的私有擴展!

在您網站中使用sql
  • RDBMS 資料庫程式(比如 MS Access, SQL Server, MySQL)
  • 服務器端腳本語言(比如 PHP 或 ASP)
  • SQL
  • HTML / CSS
RDBMS
  • RDBMS 指的是關系型資料庫管理系統,

    RDBMS 是 SQL 的基礎,同樣也是所有現代資料庫系統的基礎,比如 MS SQL Server, IBM DB2, Oracle, MySQL 以及 Microsoft Access,

    RDBMS 中的資料存盤在被稱為表(tables)的資料庫物件中,

    表是相關的資料項的集合,它由列和行組成,

sql語法

資料庫表
  • 一個資料庫通常包含一個或多個表,每個表由一個名字標識(例如“客戶”或者“訂單”),表包含帶有資料的記錄(行),

    下面的例子是一個名為 “Persons” 的表:

    IdLastNameFirstNameAddressCity
    1AdamsJohnOxford StreetLondon
    2BushGeorgeFifth AvenueNew York
    3CarterThomasChangan StreetBeijing
    • 上面的表包含三條記錄(每一條對應一個人)和五個列(Id、姓、名、地址和城市),
sql陳述句
  • 您需要在資料庫上執行的大部分作業都由 SQL 陳述句完成,

    下面的陳述句從表中選取 LastName 列的資料:

    SELECT LastName FROM Persons
    
  • 結果集類似這樣:

    LastName
    Adams
    Bush
    Carter
SQL DML 和DDL
  • 可以把 SQL 分為兩個部分:資料操作語言 (DML) 和 資料定義語言 (DDL),

    SQL (結構化查詢語言)是用于執行查詢的語法,但是 SQL 語言也包含用于更新、插入和洗掉記錄的語法,

    查詢和更新指令構成了 SQL 的 DML 部分:

    • SELECT - 從資料庫表中獲取資料
    • UPDATE - 更新資料庫表中的資料
    • DELETE - 從資料庫表中洗掉資料
    • INSERT INTO - 向資料庫表中插入資料
  • SQL 的資料定義語言 (DDL) 部分使我們有能力創建或洗掉表格,我們也可以定義索引(鍵),規定表之間的鏈接,以及施加表間的約束,

    SQL 中最重要的 DDL 陳述句:

    • CREATE DATABASE - 創建新資料庫
    • ALTER DATABASE - 修改資料庫
    • CREATE TABLE - 創建新表
    • ALTER TABLE - 變更(改變)資料庫表
    • DROP TABLE - 洗掉表
    • CREATE INDEX - 創建索引(搜索鍵)
    • DROP INDEX - 洗掉索引

sql select

sql select 陳述句
  • SELECT 陳述句用于從表中選取資料,

    結果被存盤在一個結果表中(稱為結果集),

  • sql select語法

    SELECT 列名稱 FROM 表名稱
    
    SELECT * FROM 表名稱
    
    • 對大小寫不敏感,SELECT 等效于 select,
sql select實體
  • 如需獲取名為 “LastName” 和 “FirstName” 的列的內容(從名為 “Persons” 的資料庫表),請使用類似這樣的 SELECT 陳述句:

    SELECT LastName,FirstName FROM Persons
    
  • “Persons”表

    IdLastNameFirstNameAddressCity
    1AdamsJohnOxford StreetLondon
    2BushGeorgeFifth AvenueNew York
    3CarterThomasChangan StreetBeijing

    結果

    LastNameFirstName
    AdamsJohn
    BushGeorge
    CarterThomas
sql select *實體
  • 現在我們希望從 “Persons” 表中選取所有的列,

    請使用符號 * 取代列的名稱,就像這樣:

    SELECT * FROM Persons
    
    • 提示:星號(*)是選取所有列的快捷方式,

    結果

    IdLastNameFirstNameAddressCity
    1AdamsJohnOxford StreetLondon
    2BushGeorgeFifth AvenueNew York
    3CarterThomasChangan StreetBeijing

sql select distinct

sql select distinct陳述句
  • 在表中,可能會包含重復值,這并不成問題,不過,有時您也許希望僅僅列出不同(distinct)的值,

    關鍵詞 DISTINCT 用于回傳唯一不同的值,

  • 語法

    SELECT DISTINCT 列名稱 FROM 表名稱
    
使用distinct關鍵詞
  • 如果要從 “Company” 列中選取所有的值,我們需要使用 SELECT 陳述句:

    SELECT Company FROM Orders
    
    • order 表

      CompanyOrderNumber
      IBM3532
      W3School2356
      Apple4698
      W3School6953

      結果

      Company
      IBM
      W3School
      Apple
      W3School
  • 請注意,在結果集中,W3School 被列出了兩次,

    如需從 Company" 列中僅選取唯一不同的值,我們需要使用 SELECT DISTINCT 陳述句:

    SELECT DISTINCT Company FROM Orders 
    

    結果

    Company
    IBM
    W3School
    Apple

sql where陳述句

where陳述句
  • 語法

    SELECT 列名稱 FROM 表名稱 WHERE 列 運算子 值
    
  • 下面的運算子可在 WHERE 子句中使用:

    運算子描述
    =等于
    <>不等于
    >大于
    <小于
    >=大于等于
    <=小于等于
    BETWEEN在某個范圍內
    LIKE搜索某種模式
    • 注釋:在某些版本的 SQL 中,運算子 <> 可以寫為 !=,
使用where陳述句
  • 如果只希望選取居住在城市 “Beijing” 中的人,我們需要向 SELECT 陳述句添加 WHERE 子句:

    SELECT * FROM Persons WHERE City='Beijing'
    
  • persons 表

    LastNameFirstNameAddressCityYear
    AdamsJohnOxford StreetLondon1970
    BushGeorgeFifth AvenueNew York1975
    CarterThomasChangan StreetBeijing1980
    GatesBillXuanwumen 10Beijing1985

    結果

    LastNameFirstNameAddressCityYear
    CarterThomasChangan StreetBeijing1980
    GatesBillXuanwumen 10Beijing1985
引號的使用
  • 文本值

    這是正確的:
    SELECT * FROM Persons WHERE FirstName='Bush'
    
    這是錯誤的:
    SELECT * FROM Persons WHERE FirstName=Bush
    
  • 數值

    這是正確的:
    SELECT * FROM Persons WHERE Year>1965
    
    這是錯誤的:
    SELECT * FROM Persons WHERE Year>'1965'
    

sql and & or 運算子

  • AND 和 OR 運算子用于基于一個以上的條件對記錄進行過濾,
and和or 運算子
  • AND 和 OR 可在 WHERE 子陳述句中把兩個或多個條件結合起來,

    如果第一個條件和第二個條件都成立,則 AND 運算子顯示一條記錄,

    如果第一個條件和第二個條件中只要有一個成立,則 OR 運算子顯示一條記錄,

  • 原始的表(用在例子中):

    LastNameFirstNameAddressCity
    AdamsJohnOxford StreetLondon
    BushGeorgeFifth AvenueNew York
    CarterThomasChangan StreetBeijing
    CarterWilliamXuanwumen 10Beijing
and運算子實體
  • 使用 AND 來顯示所有姓為 “Carter” 并且名為 “Thomas” 的人:
SELECT * FROM Persons WHERE FirstName='Thomas' AND LastName='Carter'

結果

LastNameFirstNameAddressCity
CarterThomasChangan StreetBeijing
or運算子實體
  • 使用 OR 來顯示所有姓為 “Carter” 或者名為 “Thomas” 的人:

    SELECT * FROM Persons WHERE firstname='Thomas' OR lastname='Carter'
    

    結果

    LastNameFirstNameAddressCity
    CarterThomasChangan StreetBeijing
    CarterWilliamXuanwumen 10Beijing
結合and和or運算子
  • 我們也可以把 AND 和 OR 結合起來(使用圓括號來組成復雜的運算式):

    SELECT * FROM Persons WHERE (FirstName='Thomas' OR FirstName='William')
    AND LastName='Carter'
    

    結果

    LastNameFirstNameAddressCity
    CarterThomasChangan StreetBeijing
    CarterWilliamXuanwumen 10Beijing

sql order by陳述句

  • order by 陳述句用于對結果集的行排序
order by陳述句
  • ORDER BY 陳述句用于根據指定的列對結果集進行排序,

    ORDER BY 陳述句默認按照升序對記錄進行排序,

    如果您希望按照降序對記錄進行排序,可以使用 DESC 關鍵字,

原始的表(用在例子中的)
  • order表:

    CompanyOrderNumber
    IBM3532
    W3School2356
    Apple4698
    W3School6953
實體1
  • 以字母順序顯示公司名稱:

    SELECT Company, OrderNumber FROM Orders ORDER BY Company
    

    結果

    CompanyOrderNumber
    Apple4698
    IBM3532
    W3School6953
    W3School2356
實體2
  • 以字母順序顯示公司名稱(Company),并以數字順序顯示順序號(OrderNumber):

    SELECT Company, OrderNumber FROM Orders ORDER BY Company, OrderNumber
    

    結果

    CompanyOrderNumber
    Apple4698
    IBM3532
    W3School2356
    W3School6953
實體3
  • 以逆字母順序顯示公司名稱:

    SELECT Company, OrderNumber FROM Orders ORDER BY Company DESC
    

    結果

    CompanyOrderNumber
    W3School6953
    W3School2356
    IBM3532
    Apple4698
實體4
  • 以逆字母順序顯示公司名稱,并以數字順序顯示順序號:

    SELECT Company, OrderNumber FROM Orders ORDER BY Company DESC, OrderNumber ASC
    

    結果

    CompanyOrderNumber
    W3School2356
    W3School6953
    IBM3532
    Apple4698

sql insert 陳述句

insertinto陳述句用于表格中插入新的行
  • 語法

    INSERT INTO 表名稱 VALUES (1,2,....)
    
  • 我們也可以指定所要插入資料的列:

    INSERT INTO table_name (1,2,...) VALUES (1,2,....)
    
插入新的行
  • persons表

    LastNameFirstNameAddressCity
    CarterThomasChangan StreetBeijing
  • sql 陳述句

    INSERT INTO Persons VALUES ('Gates', 'Bill', 'Xuanwumen 10', 'Beijing')
    

    結果

    LastNameFirstNameAddressCity
    CarterThomasChangan StreetBeijing
    GatesBillXuanwumen 10Beijing
在指定的列中插入資料
  • persons 表

    LastNameFirstNameAddressCity
    CarterThomasChangan StreetBeijing
    GatesBillXuanwumen 10Beijing
  • sql陳述句

    INSERT INTO Persons (LastName, Address) VALUES ('Wilson', 'Champs-Elysees')
    

    結果

    LastNameFirstNameAddressCity
    CarterThomasChangan StreetBeijing
    GatesBillXuanwumen 10Beijing
    WilsonChamps-Elysees

sql update陳述句

update 陳述句
  • Update 陳述句用于修改表中的資料,
語法
UPDATE 表名稱 SET 列名稱 = 新值 WHERE 列名稱 = 某值
persons表
LastNameFirstNameAddressCity
GatesBillXuanwumen 10Beijing
WilsonChamps-Elysees
更新某一行中的一個列
  • 我們為 lastname 是 “Wilson” 的人添加 firstname:

    UPDATE Person SET FirstName = 'Fred' WHERE LastName = 'Wilson' 
    

    結果

    LastNameFirstNameAddressCity
    GatesBillXuanwumen 10Beijing
    WilsonFredChamps-Elysees
更新某一行中的若干列
  • 我們會修改地址(address),并添加城市名稱(city):

    UPDATE Person SET Address = 'Zhongshan 23', City = 'Nanjing'
    WHERE LastName = 'Wilson'
    

    結果

    LastNameFirstNameAddressCity
    GatesBillXuanwumen 10Beijing
    WilsonFredZhongshan 23Nanjing

sql delete陳述句

delete陳述句
  • DELETE 陳述句用于洗掉表中的行,
語法
DELETE FROM 表名稱 WHERE 列名稱 =
person表:
LastNameFirstNameAddressCity
GatesBillXuanwumen 10Beijing
WilsonFredZhongshan 23Nanjing
洗掉某行
  • fred willson 會被洗掉

    DELETE FROM Person WHERE LastName = 'Wilson' 
    

    結果

    LastNameFirstNameAddressCity
    GatesBillXuanwumen 10Beijing
洗掉所有的行
  • 可以在不洗掉表的情況下洗掉所有的行,這意味著表的結構、屬性和索引都是完整的:

    DELETE FROM table_name
    

    或者

    DELETE * FROM table_name
    

轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/218502.html

標籤:其他

上一篇:已經有dll檔案,報錯:“缺少XXXXX.dll 無法繼續執行代碼。重新安裝程式可能會解決此問題”解決方案

下一篇:【年薪百萬之IT界大神成長之路二】手把手教你開資料庫死鎖

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【從零開始擼一個App】Dagger2

    Dagger2是一個IOC框架,一般用于Android平臺,第一次接觸的朋友,一定會被搞得暈頭轉向。它延續了Java平臺Spring框架代碼碎片化,注解滿天飛的傳統。嘗試將各處代碼片段串聯起來,理清思緒,真不是件容易的事。更不用說還有各版本細微的差別。 與Spring不同的是,Spring是通過反射 ......

    uj5u.com 2020-09-10 06:57:59 more
  • Flutter Weekly Issue 66

    新聞 Flutter 季度調研結果分享 教程 Flutter+FaaS一體化任務編排的思考與設計 詳解Dart中如何通過注解生成代碼 GitHub 用對了嗎?Flutter 團隊分享如何管理大型開源專案 插件 flutter-bubble-tab-indicator A Flutter librar ......

    uj5u.com 2020-09-10 06:58:52 more
  • Proguard 常用規則

    介紹 Proguard 入口,如何查看輸出,如何使用 keep 設定入口以及使用實體,如何配置壓縮,混淆,校驗等規則。

    ......

    uj5u.com 2020-09-10 06:59:00 more
  • Android 開發技術周報 Issue#292

    新聞 Android即將獲得類AirDrop功能:可向附近設備快速分享檔案 谷歌為安卓檔案管理應用引入可安全隱藏資料的Safe Folder功能 Android TV新主界面將顯示電影、電視節目和應用推薦內容 泄露的Android檔案暗示了傳說中的谷歌Pixel 5a與折疊屏新機 谷歌發布Andro ......

    uj5u.com 2020-09-10 07:00:37 more
  • AutoFitTextureView Error inflating class

    報錯: Binary XML file line #0: Binary XML file line #0: Error inflating class xxx.AutoFitTextureView 解決: <com.example.testy2.AutoFitTextureView android: ......

    uj5u.com 2020-09-10 07:00:41 more
  • 根據Uri,Cursor沒有獲取到對應的屬性

    Android: 背景:呼叫攝像頭,拍攝視頻,指定保存的地址,但是回傳的Cursor檔案,只有名稱和大小的屬性,沒有其他諸如時長,連ID屬性都沒有 使用 cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Video.Media.DURATIO ......

    uj5u.com 2020-09-10 07:00:44 more
  • Android連載29-持久化技術

    一、持久化技術 我們平時所使用的APP產生的資料,在記憶體中都是瞬時的,會隨著斷電、關機等丟失資料,因此android系統采用了持久化技術,用于存盤這些“瞬時”資料 持久化技術包括:檔案存盤、SharedPreference存盤以及資料庫存盤,還有更復雜的SD卡記憶體儲。 二、檔案存盤 最基本存盤方式, ......

    uj5u.com 2020-09-10 07:00:47 more
  • Android Camera2Video整合到自己專案里

    背景: Android專案里呼叫攝像頭拍攝視頻,原本使用的 MediaStore.ACTION_VIDEO_CAPTURE, 后來因專案需要,改成了camera2 1.Camera2Video 官方demo有點問題,下載后,不能直接整合到專案 問題1.多次拍攝視頻崩潰 問題2.雙擊record按鈕, ......

    uj5u.com 2020-09-10 07:00:50 more
  • Android 開發技術周報 Issue#293

    新聞 谷歌為Android TV開發者提供多種新功能 Android 11將自動填表功能整合到鍵盤輸入建議中 谷歌宣布Android Auto即將支持更多的導航和數字停車應用 谷歌Pixel 5只有XL版本 搭載驍龍765G且將比Pixel 4更便宜 [圖]Wear OS將迎來重磅更新:應用啟動時間 ......

    uj5u.com 2020-09-10 07:01:38 more
  • 海豚星空掃碼投屏 Android 接收端 SDK 集成 六步驟

    掃碼投屏,開放網路,獨占設備,不需要額外下載軟體,微信掃碼,發現設備。支持標準DLNA協議,支持倍速播放。視頻,音頻,圖片投屏。好點意思。還支持自定義基于 DLNA 擴展的操作動作。好像要收費,沒體驗。 這里簡單記錄一下集成程序。 一 跟目錄的build.gradle添加私有mevan倉庫 mave ......

    uj5u.com 2020-09-10 07:01:43 more
最新发布
  • 歡迎頁輪播影片

    如圖,引導開始,球從上落下,同時淡入文字,然后文字開始輪播,最后一頁時停止,點擊進入首頁。 在來看看效果圖。 重力球先不講,主要歡迎輪播簡單實作 首先新建一個類 TextTranslationXGuideView,用于影片展示 文本是類似的,最后會有個圖片箭頭影片,布局很簡單,就是一個 TextVi ......

    uj5u.com 2023-04-20 08:40:31 more
  • 【FAQ】關于華為推送服務因營銷訊息頻次管控導致服務通訊類訊息

    一. 問題描述 使用華為推送服務下發IM訊息時,下發訊息請求成功且code碼為80000000,但是手機總是收不到訊息; 在華為推送自助分析(Beta)平臺查看發現,訊息發送觸發了頻控。 二. 問題原因及背景 2023年1月05日起,華為推送服務對咨詢營銷類訊息做了單個設備每日推送數量上限管理,具體 ......

    uj5u.com 2023-04-20 08:40:11 more
  • 歡迎頁輪播影片

    如圖,引導開始,球從上落下,同時淡入文字,然后文字開始輪播,最后一頁時停止,點擊進入首頁。 在來看看效果圖。 重力球先不講,主要歡迎輪播簡單實作 首先新建一個類 TextTranslationXGuideView,用于影片展示 文本是類似的,最后會有個圖片箭頭影片,布局很簡單,就是一個 TextVi ......

    uj5u.com 2023-04-20 08:39:36 more
  • 【FAQ】關于華為推送服務因營銷訊息頻次管控導致服務通訊類訊息

    一. 問題描述 使用華為推送服務下發IM訊息時,下發訊息請求成功且code碼為80000000,但是手機總是收不到訊息; 在華為推送自助分析(Beta)平臺查看發現,訊息發送觸發了頻控。 二. 問題原因及背景 2023年1月05日起,華為推送服務對咨詢營銷類訊息做了單個設備每日推送數量上限管理,具體 ......

    uj5u.com 2023-04-20 08:39:13 more
  • iOS從UI記憶體地址到讀取成員變數(oc/swift)

    開發除錯時,我們發現bug時常首先是從UI顯示發現例外,下一步才會去定位UI相關連的資料的。XCode有給我們提供一系列debug工具,但是很多人可能還沒有形成一套穩定的除錯流程,因此本文嘗試解決這個問題,順便提出一個暴論:UI顯示例外問題只需要兩個步驟就能完成定位作業的80%: 定位例外 UI 組 ......

    uj5u.com 2023-04-19 09:16:23 more
  • FIDE重磅更新!性能飛躍!體驗有禮!

    FIDE 開發者工具重構升級啦!實作500%性能提升,誠邀體驗! 一直以來不少開發者朋友在社區反饋,在使用 FIDE 工具的程序中,時常會遇到諸如加載不及時、代碼預覽/渲染性能不如意的情況,十分影響開發體驗。 作為技術團隊,我們深知一件趁手的開發工具對開發者的重要性,因此,在2023年開年,FinC ......

    uj5u.com 2023-04-19 09:16:15 more
  • 游戲內嵌社區服務開放,助力開發者提升玩家互動與留存

    華為 HMS Core 游戲內嵌社區服務提供快速訪問華為游戲中心論壇能力,支持玩家直接在游戲內瀏覽帖子和交流互動,助力開發者擴展內容生產和觸達的場景。 一、為什么要游戲內嵌社區? 二、游戲內嵌社區的典型使用場景 1、游戲內打開論壇 您可以在游戲內繪制論壇入口,為玩家提供沉浸式發帖、瀏覽、點贊、回帖、 ......

    uj5u.com 2023-04-19 09:15:46 more
  • iOS從UI記憶體地址到讀取成員變數(oc/swift)

    開發除錯時,我們發現bug時常首先是從UI顯示發現例外,下一步才會去定位UI相關連的資料的。XCode有給我們提供一系列debug工具,但是很多人可能還沒有形成一套穩定的除錯流程,因此本文嘗試解決這個問題,順便提出一個暴論:UI顯示例外問題只需要兩個步驟就能完成定位作業的80%: 定位例外 UI 組 ......

    uj5u.com 2023-04-19 09:14:53 more
  • FIDE重磅更新!性能飛躍!體驗有禮!

    FIDE 開發者工具重構升級啦!實作500%性能提升,誠邀體驗! 一直以來不少開發者朋友在社區反饋,在使用 FIDE 工具的程序中,時常會遇到諸如加載不及時、代碼預覽/渲染性能不如意的情況,十分影響開發體驗。 作為技術團隊,我們深知一件趁手的開發工具對開發者的重要性,因此,在2023年開年,FinC ......

    uj5u.com 2023-04-19 09:14:08 more
  • 游戲內嵌社區服務開放,助力開發者提升玩家互動與留存

    華為 HMS Core 游戲內嵌社區服務提供快速訪問華為游戲中心論壇能力,支持玩家直接在游戲內瀏覽帖子和交流互動,助力開發者擴展內容生產和觸達的場景。 一、為什么要游戲內嵌社區? 二、游戲內嵌社區的典型使用場景 1、游戲內打開論壇 您可以在游戲內繪制論壇入口,為玩家提供沉浸式發帖、瀏覽、點贊、回帖、 ......

    uj5u.com 2023-04-19 09:08:34 more