(<列名列表>)VALUES(<值列表>)如:INSERTINTOt_student(student_id,student_name,student_age,student_sex)VALUES(1,'大毛',18,'男');其中列名可以省略,省略之后要求插入的值必須與列一一對應:INSERTINTOt_studen" />

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

SQL語句匯總(二)——數據修改、數據查詢

系統 1652 0

SQL語句第二篇,不說廢話直接開始吧。

?

首先創建一張表如下,創建表的方法在上篇介紹過了,這里就不再贅述。

?

添加新數據:

      
        INSERT
      
      
        INTO
      
      
        <
      
      表名
      
        >
      
       (
      
        <
      
      列名列表
      
        >
      
      ) 
      
        VALUES
      
       (
      
        <
      
      值列表
      
        >
      
      )?
    

如:

      
        INSERT
      
      
        INTO
      
       t_student (student_id,student_name,student_age,student_sex) 
      
        VALUES
      
       (
      
        1
      
      ,
      
        '
      
      
        大毛
      
      
        '
      
      ,
      
        18
      
      ,
      
        '
      
      
      
        '
      
      );
    

其中列名可以省略,省略之后要求插入的值必須與列一一對應:

      
        INSERT
      
      
        INTO
      
       t_student 
      
        VALUES
      
       (
      
        2
      
      ,
      
        '
      
      
        王二
      
      
        '
      
      ,
      
        20
      
      ,
      
        '
      
      
      
        '
      
      );
    

多行數據添加:

      
        INSERT
      
      
        INTO
      
       t_student 
      
        VALUES
      
       (
      
        3
      
      ,
      
        '
      
      
        張三
      
      
        '
      
      ,
      
        22
      
      ,
      
        '
      
      
      
        '
      
      
        ),

                 (
      
      
        4
      
      ,
      
        '
      
      
        李四
      
      
        '
      
      ,
      
        17
      
      ,
      
        '
      
      
      
        '
      
      
        ),

                 (
      
      
        5
      
      ,
      
        '
      
      
        王五
      
      
        '
      
      ,
      
        23
      
      ,
      
        '
      
      
      
        '
      
      );
    

SQL語句匯總(二)——數據修改、數據查詢

?

更改數據:

      
        UPDATE
      
       表名 
      
        SET
      
       列1
      
        =
      
      新值1,列2
      
        =
      
      新值2 
      
        WHERE
      
       過濾條件
    

假如要修改李四的年齡為21歲

      
        UPDATE
      
       t_student 
      
        SET 
      
      student_age
      
        =
      
      
        21
      
      
        WHERE 
      
      student_name
      
        =
      
      
        '
      
      
        李四
      
      
        '
      
      ;
    

SQL語句匯總(二)——數據修改、數據查詢

注:修改多個列的值時用逗號隔開。要想設置某一列的值為空,只需讓<列名>=NULL 即可。WHERE表示過濾條件。

?

刪除數據(行): ?

      
        DELETE
      
      
        FROM
      
       表名 
      
        WHERE
      
       過濾條件
    

現要刪除20到22歲的學生信息:

      
        DELETE
      
      
        FROM
      
       t_student 
      
        WHERE
      
       student_age 
      
        BETWEEN
      
      
        20
      
      
        AND
      
      
        22
      
      ;
    

WHERE的判斷條件之后會更詳細的介紹。

刪除除了DELETE還有一種方法 TRUNCATE,寫法:

      
        TRUNCATE
      
      
        TABLE
      
       表名
    

二者區別在于:

DELETE會記錄日志,意味著刪除后的數據還可以恢復,但是效率低。TRUNCATE不會記錄日志,刪除后的數據不能恢復,但是效率高。需要注意的是,TRUNCATE不能用于有外鍵約束引用的表。

?

查詢操作

分類:

–投影操作
  指定查詢結果中能顯示哪些列
–選擇操作
  指定哪些行出現在結果中
–排序操作
  指定查詢的結果以什么樣的順序顯示
?
投影操作:
          
            SELECT
          
           列1,列2 
          
            FROM
          
           表名
        

多個列中間用逗號隔開,如果選擇所有列可以用*號簡寫。

還是此表:

SQL語句匯總(二)——數據修改、數據查詢

現在只想要查看姓名和年齡列:

          
            SELECT
          
           student_name,student_age 
          
            FROM
          
           t_student;
        

SQL語句匯總(二)——數據修改、數據查詢

注意這里不是把其他列刪除了,而是只顯示我們想看見的部分。

          
            SELECT
          
           CONCAT(student_name,
          
            '
          
          
            ——
          
          
            '
          
          ,student_age) 
          
            '
          
          
            組合值
          
          
            '
          
          
            FROM
          
           t_student;
        

CONCAT,可以將列與列之間用想要的符號連接起來:

SQL語句匯總(二)——數據修改、數據查詢

?

排除重復——DISTINCT

現給原表加入一班級列:

SQL語句匯總(二)——數據修改、數據查詢

按照之前方法查詢班級列得到:

SQL語句匯總(二)——數據修改、數據查詢

但是我們只想查看具體有哪些班級,這里就需要用到去重,也就是 DISTINCT

          
            SELECT
          
          
            DISTINCT
          
           student_class 
          
            FROM
          
           t_student;
        

?

返回限定行數的查詢——LIMIT

LIMIT后面參數為1或2個:

LIMIT N 表示從第一行開始返回N行結果,LIMIT i,N 表示從第i+1行開始返回N行結果。

例:

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student LIMIT 
      
        3
      
      ;
    

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student LIMIT 
      
        2
      
      ,
      
        3
      
      ;
    

*注:LIMIT很重要,它是之后做數據表格分頁的關鍵。

?

選擇操作——WHERE:

分為單條件選擇與多條件選擇

單條件選擇標準結構:

      
        SELECT
      
       列1, 列2 
      
        FROM
      
       表名 
      
        WHERE
      
       列3 
      
        =
      
       值?
    

關系運算符包括:> ?>= ?< ?<= ?= ?!=

多條件選擇標準結構:

      
        SELECT
      
       列A, 列B 
      
        FROM
      
        WHERE
      
       條件1 (
      
        AND
      
      或者OR) 條件2
    

其中AND表示并且,OR表示或者。

?

選擇范圍——BETWEEN

如:

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student 
      
        WHERE
      
       student_age 
      
        BETWEEN
      
      
        20
      
      
        AND
      
      
        23
      
      ;
    

BETWEEN后的值為從下限到上限。

?

定義集合——IN或NOT IN

現在想查看年齡為17、20、23的學生信息: ?

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student 
      
        WHERE
      
       student_age 
      
        IN
      
       (
      
        17
      
      ,
      
        20
      
      ,
      
        23
      
      );
    

反之NOT IN就是選擇不包括在集合里的學生信息。

?

模糊查詢——LIKE

為了更好的解釋模糊查詢,這里重新建張表:

SQL語句匯總(二)——數據修改、數據查詢

這里姓王的兄弟們躺槍...別介意。

首先先說下占位符與通配符:

占位符 "_",表示任何單個字符。

通配符 "%",表示包含零或多個字符。

下面就來用模糊查詢逐一選中我們想要的行。

名字只有兩個字的:

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student 
      
        WHERE
      
       student_name 
      
        LIKE
      
      
        '
      
      
        __
      
      
        '
      
      ;
    

這里可能看不清,引號里實際是兩個占位符。

所有姓王的:

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student 
      
        WHERE
      
       student_name 
      
        LIKE
      
      
        '
      
      
        王%
      
      
        '
      
      ;
    

最后一個字 是“王”的:

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student 
      
        WHERE
      
       student_name 
      
        LIKE
      
      
        '
      
      
        %王
      
      
        '
      
      ;
    

只要是名字中有“王”字的:

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student 
      
        WHERE
      
       student_name 
      
        LIKE
      
      
        '
      
      
        %王%
      
      
        '
      
      ;
    

SQL語句匯總(二)——數據修改、數據查詢

這下模糊查詢就很明白了吧,當然還有其他組合,大家可以自己嘗試。

?

處理空值數據:

判斷條件不能用列名=NULL,而是要用IS NULL或IS NOT NULL。

標準寫法:

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student 
      
        WHERE
      
       性別 
      
        IS
      
      
        NULL
      
    

?

排序操作——ORDER BY:

使用ORDER BY時,列名上指定ASC或DESC。ASC表示正序,DESC表示倒序。如果不指定則默認為正序。

按年齡排:

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student 
      
        ORDER
      
      
        BY
      
       student_age 
      
        ASC
      
      ;
    

SQL語句匯總(二)——數據修改、數據查詢

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student 
      
        ORDER
      
      
        BY
      
       student_age 
      
        DESC
      
      ;
    

SQL語句匯總(二)——數據修改、數據查詢

?

最后一定要注意!

基本查詢SQL的執行順序:

1.執行FROM 2.WHERE條件過濾 3.SELECT投影 4.ORDER BY排序

?

SQL的第二篇就到這里了,博主寫的快吐了!感覺學的時候沒這么多啊,希望各位認同的朋友頂一下,也好讓我有動力寫完。

SQL語句匯總(二)——數據修改、數據查詢


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产在线精品一区免费香蕉 | 亚洲综合视频一区 | 在线视频综合网 | 日韩欧美视频在线播放 | 国产黄色一级大片 | 国产日韩精品一区在线观看播放 | 亚洲影院中文字幕 | 性生活视频免费 | 深夜在线观看 | 亚洲欧美日韩中文无线码 | 波多野结衣日韩 | 91视频青娱乐 | 久久久91精品国产一区二区三区 | 奇米狠狠| 亚洲日韩欧美一区二区在线 | 亚洲免费一级片 | 成人深夜视频在线观看 | 日本大片免费一级 | 羞羞视频在线免费 | 国产亚洲欧洲 | 亚洲乱码一区二区三区在线观看 | 97影院理论在线观看 | 亚洲精品一区二区久久这里 | 欧美日韩在线免费观看 | 不卡中文字幕在线观看 | 成人免费精品视频 | 久久r这里只有精品 | 亚洲欧美字幕 | 久久久久久极精品久久久 | 正在播放国产乱子伦视频 | 国产成人综合91香蕉 | 久久精品国产99国产精品免费看 | 日日夜夜精品 | 亚洲第一永久在线观看 | 日韩久久网 | 亚洲精品视频在线观看视频 | 成人亚洲欧美 | 免费看一级黄色录像 | 神马影院不卡不卡在线观看 | 天天干狠狠操 | 涩涩免费播放观看在线视频 |