中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SELECT 1 FROM TABLE,SQL語句中的1代表什么意思

發布時間:2020-07-13 13:22:35 來源:網絡 閱讀:1733 作者:MChopin 欄目:關系型數據庫

select 1 from table; 與 select anycol(目的表集合中的任意一行)from table; 與 select from table;
從作用上來說是沒有差別的,都是查看是否有記錄,一般是作條件查詢用的。select 1 from table中的1是一常量(可以為任意數值),查到的所有行的值都是它,但從效率上來說,1>anycol>
,因為不用查字典表。

注意:

當我們只關心數據表有多少記錄行而不需要知道具體的字段值時,類似“select 1 from table”是一個很不錯的SQL語句寫法,它通常用于子查詢。
這樣可以減少系統開銷,提高運行效率。因為這樣寫的SQL語句,數據庫引擎就不會去檢索數據表里每條具體的記錄和每條記錄里每個具體的字段值并將它們放到內存里,而是根據查詢到有多少記錄行存在就輸出多少個“1”,每個“1”代表有1行記錄,同時選用數字1還因為它所占用的內存空間最小,當然用數字0的效果也一樣。

測試:

  1. select 1 from table 增加臨時列,每行的列值是寫在select后的數。這條sql語句中是1
  2. select count(1) from table 不管count(a) 的 a值如何變化,得出的值總是table表的行數
  3. select sum(1) from table 計算臨時列的和

在Oracle中用 1 測試了一下,發現結果如下:

  1. 測試結果,得出一個行數和table表行數一樣的臨時列,每行的列值是1;
  2. 得出一個數,該數是table表的行數;
  3. 得出一個數,該數是table表的行數;

然后又用“2”測試,結果如下:

  1. 得出一個行數和table表行數一樣的臨時列,每行的列值是2;
  2. 得出一個數,該數是table表的行數;
  3. 得出一個數,該數是table表的行數×2的數

再用不同的數測試

  1. 得出一個行數和table表行數一樣的臨時列,每行的列值是寫在select后的數;
  2. 還是得出一個數,該數是table表的行數;
  3. 得出一個數,該數是table表的行數×寫在select后的數

綜上所述:第一種的寫法是增加臨時列,每行的列值是寫在select后的數;第二種是不管count(a)的a值如何變化,得出的值總是table表的行數;第三種是計算臨時列的和。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

聂荣县| 揭西县| 全南县| 嘉禾县| 奉化市| 息烽县| 象州县| 锦屏县| 盐边县| 拉孜县| 清新县| 塔城市| 新闻| 萨嘎县| 信阳市| 霍邱县| 盐城市| 定襄县| 长武县| 靖宇县| 镇原县| 齐齐哈尔市| 建昌县| 盐源县| 太保市| 宜都市| 玉溪市| 元氏县| 宜阳县| 十堰市| 梓潼县| 广州市| 宜兴市| 阿鲁科尔沁旗| 叙永县| 凤翔县| 沙雅县| 阿克陶县| 图木舒克市| 孝义市| 威信县|