首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

01-03章 检索排序数据第1章 了解SQL第2章 检索数据第3章

以上SELECT语句将返回表中所有行,数据没有过滤。 多条SQL语句必须以分号(;)分隔。 SQL关键字应大写,列名和表名应小写。...屏幕快照 2018-05-24 05.34.56.png 说明 SQL语句一般返回原始的、无格式的数据。数据的格式化是表示问题,而不是检索问题。...因此,表示(如把上面的价格值显示为正确的十进制数值货币金额)一般在显示该数据的应用程序中规定。 2.4 检索所有列 SELECT语句可以检索所有的列,在实际列名的位置使用星号(*)通配符。...使用DISTINCT关键字,作用于所有列,指示数据库只返回不同的值。 SELECT DISTINCT vend_id FROM Products; ?...屏幕快照 2018-05-26 19.35.57.png 分析 SELECT 清单中指定的是选择列的相对位置而不是列名。

2.6K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【重学MySQL】十三、基本的 select 语句

    DUAL表允许你执行没有指定FROM子句的SELECT语句,这在一些情况下特别有用,比如当你只是想通过SELECT语句来执行一些计算或转换,而不是查询表中的数据时。...但在MySQL中,你可以直接写: SELECT 5 * 10; 这条语句同样会返回50,而不需要引用DUAL表。...基本的列别名使用 在SELECT语句中,你可以通过在列名后紧跟AS关键字和别名来指定列的别名。...DISTINCT通常与SELECT语句一起使用,放在需要返回唯一值的列名之前。你也可以对多个列使用DISTINCT,但这意味着MySQL会考虑这些列的组合作为唯一性的判断依据。...如果查询中包含了聚合函数(如COUNT()、MAX()、MIN()、SUM()等),并且你想要基于某些列的唯一值来计算聚合结果,那么可能需要结合GROUP BY子句来使用,而不是直接使用DISTINCT

    17610

    有哪些常用的sql语句

    还有就是一些要注意的地方,就是SQL语句对大小写不敏感,语句中列名对应的值要用单引号''括起来不是双引号。 SQL 使用单引号来环绕文本值。...简单点来说,这是一种模糊搜索,而“%”可以代表任何字符。 5、and,or and 即条件交集,or 即条件并集; 二、改:Update 语句用于修改表中的数据。...OrderTotal 六、count()函数 1、COUNT(column_name) 函数返回指定列的值的数目(NULL 不计入),即column_name中有多少个不同的值: SELECT COUNT...如:SELECT COUNT(DISTINCT Customer) AS NumberOfCustomers FROM Orders 注:count()函数可以统计出一个列中某一值的出现次数,而不限于列的值的数据类型...,而sum()函数限定操作的值的类型一定要是数值类型; 七、group by 1、GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组。

    2K100

    SQL命令 ORDER BY(一)

    该语句对单个结果集进行操作,这些结果集要么来自SELECT语句,要么来自多个SELECT语句的UNION。 ORDER BY按逻辑(内部存储)数据值对记录进行排序,而不考虑当前的选择模式设置。...如果在SELECT列表中没有指定列别名,则在指定聚合函数、窗口函数或表达式时,使用选择项列号(例如3),而不是默认的列名(例如Aggregate_3)。...下面的示例以与前一个示例相同的顺序返回相同的记录: SELECT Name,DOB FROM Sample.Person ORDER BY Home_State,Name 如果order -item不是指定表中现有的列名...即使RowID是私有的并且没有在选择项列表中列出,也可以按RowID值排序。 应该指定%ID伪列名作为ordering-item,而不是实际的RowID字段名。...1),$PIECE(Home_Street,' ',2),$PIECE(Home_Street,' ',3) 请注意,此示例仅适用于列名,而不适用于列别名或列编号。

    2.6K30

    MySQL(五)汇总和分组数据

    一、汇总数据 工作中经常需要汇总数据而不是将它们全部检索出来(实际数据本身:返回实际数据是对时间和处理资源的浪费),这种类型的检索有以下特点: ①确定表中的行数(或者满足某个条件或包含某个特定值的行数)...()函数忽略,但如果count()函数中用的是星号(*),则不忽略;  3、max()函数 max()返回指定列中的最大值,max()要求指定列名,例子如下: select max(prod_price...;但用于文本数据时,如果数据按相应的列排序,则max()返回最后一行(max()函数忽略列值为null的行) 4、min()函数 min()返回指定列的最小值,min()也要求指定列名,例子如下: select...,包括返回文本列的最小值;但用于文本数据时,如果数据按相应的列排序,则min()返回最前面的行(min()函数忽略列值为null的行) 5、sum()函数 sum()函数用来返回指定列值的和(总计);例子如下...by子句指示指示MySQL分组数据,然后都每个组而不是整个结果集进行聚集;关于group by使用,请注意以下规则: ①group by子句可以包含任意数目的列(使得对分组进行嵌套,为数据分组提供更细致的控制

    4.7K20

    SQL从入门到入魔之select简单查询

    未排序数据 如果没有明确排序查询结果,可能会发现显示输出的数据顺序与原表不同,返回的数据的顺序没有特殊意义,可能是数据被添加到表中的顺序,也可能不是,只要返回相同数目的行就是正常的。...#2.查询多个列:查询学生表的id,name两列的值 select id,name from stu; ? 在select关键字后给出多个列名,列名之间以逗号分隔,最后一个列名后不加逗号。...不能部分使用DISTINCT DISTINCT关键字应用于所有列而不仅是前置它的列,除非指定的两个列都不同,否则所有行都将被检索出来。...带一个值的LIMIT总是从第一行开始,给出的数为总的行数。带两个值的LIMIT可以指定从行号为第一个值的位置开始。 行0开始 检索出来的第一行为行0而不是行1。...因此,LIMIT 1, 1将检索出第二行而不是第一行。

    1.7K70

    SQL命令 INSERT(一)

    column - 可选 - 与提供的值列表顺序对应的列名或以逗号分隔的列名列表。如果省略,值列表将按列号顺序应用于所有列。...INSERT语句与SELECT查询的结合使用通常用于用从其他表中提取的现有数据填充表,如下面的“插入查询结果”部分所述。...如果只希望禁用外键引用完整性检查,请使用$SYSTEM.SQL.SetFilerRefIntegrity()方法,而不是指定%NOCHECK。...A”、换行符和字母“B”组成的字符串: INSERT INTO MyTable (Text) VALUES ('A'||CHAR(10)||'B') 请注意,要连接函数的结果,必须使用||连接运算符,而不是...特殊变量 可以在列中插入以下特殊变量的值: %TABLENAME或%CLASSNAME伪字段变量关键字。%TABLENAME返回当前表名。%CLASSNAME返回与当前表对应的类名。

    6K20

    使用动态SQL(七)

    如果为该列提供了别名,则会在此处列出该列的别名,而不是字段名称。名称和别名将被截断为12个字符。...Labellabel列名或列别名(与列名相同)。TabletableNameSQL表名称。即使为表指定了别名,也始终在此处列出实际的表名。如果SELECT项是表达式或聚合,则不会列出任何表名。...请注意,链接属性列出了持久性类名(不是SQL表名)和属性名(不是列别名)。...,"End of metadata"}它不仅返回列(字段)信息,还返回语句参数,形式参数和对象的值。以下示例返回具有三个形式参数的的元数据。这三个参数之一用问号(?)...请注意,TOP参数以数据类型12(VARCHAR)而不是数据类型4(INTEGER)返回,因为可以指定TOP ALL:/// d ##class(PHA.TEST.SQL).MetaData6()ClassMethod

    85420

    SQL常见面试题总结

    WHERE 子句作用于表和视图,HAVING 子句作用于组。 WHERE 在分组和聚集计算之前选取输入行(因此,它控制哪些行进入聚集计算), 而 HAVING 在分组和聚集之后选取分组的行。...1的个数,而是指表的第一个字段 用count对字段为null的数据可以查出来吗 不可以 对于返回的结果集,一行行地判断,如果 count 函数的参数不是 NULL,累计值就加 1,否则不加。...最后返回累计值 count(*)和count(1)哪个执行效率高 如果count(1)是聚索引 id,那肯定是count(1)快 执行效果上 count(*)包括了所有的列,相当于行数,在统计结果的时候...,不会忽略列值为NULL count(1)包括了忽略所有列,用1代表代码行,在统计结果的时候,不会忽略列值为NULL count(列名)只包括列名那一列,在统计结果的时候,会忽略列值为空(这里的空不是只空字符串或者...0,而是表示null)的计数,即某个字段值为NULL时,不统计 执行效率上 列名为主键,count(列名)会比count(1)快 列名不为主键,count(1)会比count(列名)快 如果表多个列并且没有主键

    2.3K30

    mysql 必知必会整理—sql 简单语句

    SHOW COLUMNS 要求给出一个表名(这个例子中的 FROM customers),它对每个字段返回一行,行中包含字段名、数据类型、是否允许NULL、键信息、默认值以及其他信息(如字段cust_id...简单查询语句 简单介绍一下查询语句。 检索单列: SQL语句和大小写 请注意,SQL语句不区分大小写,因此SELECT与select是相同的。同样,写成Select也没有关系。...许多SQL开发人员喜欢对所有SQL关键字使用大写,而对所有列和表名使用小写,这样做使代码更易于阅读和调试。 这里可以养好习惯,将关键字进行大写,然后将表名和列名进行小写。...不能部分使用DISTINCT DISTINCT关键字应用于所有列而不仅是前置它的列。 如果查询出来10行,但是我们只需要5,那么可以使用limit。...有一个问题,假设有两张表都有列名a1。 那么select a1 from table1,table2,这个a1 到底是table1还是table2呢?

    57420

    MySQL 教程上

    例如,SELECT 3*2;将返回 6, SELECT Trim('abc');将返回 abc,而SELECT Now() 利用 Now()函数返回当前日期和时间。...因此第一个被检索的行是第 0 行,而不是第 1 行。因此,LIMIT 2 OFFSET 1 会检索第 2 行,而不是第1行。...INSERT SELECT 中的列名 为简单起见,这个例子在 INSERT 和 SELECT 语句中使用了相同的列名。但是,不一定要求列名匹配。事实上,MySQL 甚至不关心SELECT 返回的列名。...可使用last_insert_id()函数获得这个值,如下所示:SELECT_last_insert_id() 此语句返回最后一个AUTO_INCREMENT值,然后可以将它用于后续的MySQL语句。...OrderDate datetime NOT NULL DEFAULT CURDATE(), 指定默认值 提示:使用 DEFAULT 而不是 NULL 值许多数据库开发人员喜欢使用 DEFAULT 值而不是

    3.4K10

    SQL | SQL 必知必会笔记 (一 )

    SQL 不区分大小写,但一般习惯关键字用大写,列名和表名使用小写。 处理 SQL 语句时,所有空格都会被忽略。一般认为写成多行更容易维护。 选择多个列时,一定要在列名之间加上逗号,但最后一个列名不加。...如果在最后一个列名加了逗号,会出现错误。 SQL 一般返回原始的、无格式的数据。 第一个检索的行是第 0 行,而不是第 1 行。 并非所有 SQL 实现方式 都一样。...检索不同的值 SELECT vend_id FROM Products; 使用 DISTINCT 关键字只返回不同的(唯一的)值。...SELECT DISTINCT vend_id FROM Products; DISTINCT 关键字作用于所有列,不仅仅是跟在其后那一列。...NULL 表示空值,确定是否空值,不能简单的 = NULL,SELECT 语句有一个特殊的 WHERE 子句 IS NULL ,可用来检查具有 NULL 值的列。

    2.6K51

    ❤️ 爆肝3天!两万字图文 SQL 零基础入门,不怕你学不会,就怕你不收藏!❤️

    语法: SELECT DISTINCT 列名称 FROM 表名称; 实例: 如果要从 “LASTNAME” 列中选取所有的值,我们需要使用 SELECT 语句: SELECT LASTNAME FROM...注意: 在第一列中有相同的值时,第二列是以升序排列的。如果第一列中有些值为 null 时,情况也是这样的。 ???? UPDATE – 更新数据 Update 语句用于修改表中的数据。...AVG – 平均值 AVG 函数返回数值列的平均值。NULL 值不包括在计算中。 语法: SELECT AVG(列名) FROM 表名; 实例: 计算 “orderno” 字段的平均值。...COUNT(DISTINCT 列名) :返回指定列的不同值的数目。 COUNT(列名) :返回指定列的值的数目(NULL 不计入)。...语法: SELECT MAX(列名) FROM 表名; MIN 和 MAX 也可用于文本列,以获得按字母顺序排列的最高或最低值。

    8.4K11

    SQL必知必会总结3-第14到17章

    组合查询union 什么是组合查询 SQL允许执行多个查询(多条SELECT语句),并将结果作为一个查询结果集返回,这些组合通常称为并union或者复合查询;通常两种情况下需要使用组合查询: 在一个查询中从不同的表返回结构数据...有两种删除方式: 从表中删除特定的行 从表中删除所有的行 DELETE FROM Customers WHERE cust_id = '011111111116'; DELETE是删除整行而不是删除列。...,各个列之间通过逗号隔开 每列的定义以列名开始,后紧跟数据类型 ,是否允许控制等 整条语句是以分号结束 使用NULL值 NULL值就是没有值或者缺失值。...注意NULL和空字符串的区别: NULL值没有值,不是空字符串 空字符串值一个有效的值,它不是无值 NULL值使用关键字NULL而不是空字符串指定 指定默认值 SQL中创建表的时候可以指定通过关键字DEFAULT...item_price DECIMAL(8,2) NOT NULL ); 默认值一般是用于日期或者时间戳列。

    1.4K41

    MySQL(二)数据的检索和过滤

    ; 在检索多个列时,要在列名之间加上逗号(,),最后一个列名不用加 SQL语句一般返回原始的、无格式的数据,数据的格式只是一个表示问题,而不是检索问题;因此表示方式一般在显示该数据的应用程序中规定,一般很少使用实际检索出的原始数据...告诉MySQL只返回不同的值;它必须直接放在列名的前面(distinct作用于所有列) 5、限制结果 select column from table limit N; limit告诉MySQL只返回它指定值的第一行或前几行...,给出的数为返回的行数;带两个值可以指定从行号为第一个值的位置开始) 检索出来的第一行为行0而不是行1,因此,limit1,1将检索出第二行而不是第一行(在行数不够时,MySQL将只返回能返回的最大行数...= N; where子句中,对过滤的值,有的用单引号,有的不用,原因在于:单引号用于限定字符串,如果将值与串类型的列进行比较,则需要,如用来与数值列比较,则不用引号 3、范围值检查 select column...;即:or告诉DBMS匹配任一条件而不是同时匹配两个条件 3、计算次序 select column1,column2 from table where column1 =X or column1 = Y

    4.1K30

    数据分析索引总结(上)Pandas单级索引

    list,而不是多个索引 df.loc[[1102,2304]] 多行索引时, 传入的必须是一个list, 而不是两个或多个索引, 否则会报错 #以下索引报错 # TypeError: cannot do...1102:2401:3,'Height':'Math']#.head() ⑥ 函数式索引 loc中使用的函数,传入参数就是前面的df;本质上这是一个布尔索引: lambda函数分别根据每行的Gender值列返回一个布尔值..., 然后用这个布尔值序列来筛选df的行,布尔值为真则返回,否则筛选掉。...df.iloc[3:5] ③ 单列索引 使用列名标签来返回单列,之所以选择列的语法如此简单, 是因为df本质上是将多个Series作为列拼接起来的。...索引多列时,传入的必须是一个list,而不是多个列名标签--方括号应该有两层。

    5.1K40

    GenerateTableFetch

    只有当默认查询执行得不好、没有最大值列或只有一个最大值列(其类型可以强制为长整数(即不是日期或时间戳))且列值均匀分布而不是稀疏时,才应使用此属性支持表达式语言:true(将使用流文件属性和变量注册表进行评估...只有当默认查询执行得不好、没有最大值列或只有一个最大值列(其类型可以强制为长整数(即不是日期或时间戳))且列值均匀分布而不是稀疏时,才应使用此属性 支持表达式语言:true(将使用流文件属性和变量注册表进行评估...这允许增量获取新行,而不是每次生成SQL来获取整个表。如果没有设置最大值列,那么处理器将生成SQL来每次获取整个表。...例如,如果列“id”用于值分区,然后列值100到200,页面大小为10的SQL来获取第一页可能是“SELECT * FROM myTable id > = 100和id SELECT...重要的是,将用于值分区的列设置为可以强制类型为长整数(即不是日期或时间戳)的列,并且为了获得最佳性能,列值是均匀分布的,而不是稀疏的。

    3.3K20
    领券