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

十步完全理解 SQL

注意:并非所有的数据库对 SQL 语句使用相同的解析方式。如 MySQL、PostgreSQL和 SQLite 中就不会按照上面第二点中所说的方式执行。 我们学到了什么?...上面这句 FROM 语句的输出是一张联合表,联合了表 a 和表 b 。如果 a 表有三个字段, b 表有 5 个字段,那么这个“输出表”就有 8 ( =5+3)个字段。...这个联合表里的数据是 a*b,即 a 和 b 的笛卡尔积。换句话说,也就是 a 表中的每一条数据都要跟 b 表中的每一条数据配对。...如果把一张表视图化,我们可以想象每一张表都是由横纵两个维度组成的,横向维度即我们所说的字段或者列,英文为columns;纵向维度即代表了每条数据,英文为 record ,根据上下文,作者这里所指的应该是字段数...(译者注:原文大意为“当你是用 GROUP BY 的时候,你能够对其进行下一级逻辑操作的列会减少,包括在 SELECT 中的列”)。 需要注意的是:其他字段能够使用聚合函数: ?

1.7K90

H2数据库教程_h2数据库编辑数据库

支持路径名中的空格。不得引用设置。 使用H2控制台 H2控制台应用程序有三个主要面板:顶部的工具栏,左侧的树和右侧的查询/结果面板。数据库对象(例如,表)列在左侧。...使用H2和jOOQ jOOQ在JDBC之上添加了一个薄层,允许类型安全的SQL构造,包括高级SQL,存储过程和高级数据类型。jOOQ将您的数据库模式作为代码生成的基础。...读取和写入CSV文件(此功能也可以在数据库外部使用)。 参照完整性和检查约束。 更好的数据类型和SQL支持。 内存数据库,只读数据库,链接表。 与其他数据库更好地兼容,简化了移植应用程序。...结果包含列SCHEMA(模式名称),TABLE(表名称),COLUMNS(列名称数组)和KEYS(对象数组)。...日期和时间信息存储在H2数据库文件中,根据使用的数据类型,有或没有时区信息。 使用TIMESTAMP数据类型如果使用其他系统时区打开数据库,则日期和时间将相同。

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

    SQL查询的高级应用

    例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应使用下面语句格式加以限定: SELECT username,citytable.cityid...在使用UNION 运算符时,应保证每个联合查询语句的选择列表中有相同数量的表达式,并且每个查询选择表达式应具有相同的数据类型,或是可以自动将它们转换为相同的数据类型。...连接操作给用户带来很大的灵活性,他们可以在任何时候增加新的数据类型。为不同实体创建新的表,尔后通过连接进行查询。   ...根据所使用的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。...与内连接不同的是,外连接不只列出与连接条件相匹配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的数据行。

    3K30

    SQL命令 UNION

    为了在SELECT语句之间实现联合,每个分支中指定的列数必须匹配。 指定具有不同列数的select将导致SQLCODE -9错误。...FROM Table2 如果联合分支中的列在长度、精度或比例上不同,则给结果列分配最大的值。...结果列名取自联合的第一个分支中的列(或列别名)的名称。 在两个分支中对应的列没有相同名称的情况下,在所有分支中使用相同的列别名来标识结果列可能会很有用。...UNION and UNION ALL 普通的UNION消除了结果中的重复行(所有值都相同)。 UNION ALL在结果中保留重复的行。 不同精度的字段不具有相同的值。...例如,值33(数据类型NUMERIC(9))和33.00(数据类型NUMERIC(9,2))并不被认为是相同的。 具有不同排序规则的字段没有相同的值。

    1.6K20

    《MySQL入门很轻松》第5章:数据完整性及其分类

    (1) 实体完整性:指通过表中字段或字段组合将表中各记录的唯一性区别开来。例如,在学生表中,学生之间可能姓名相同,班级编号相同,但是每个学生的学号必然不同。...在输入或删除数据记录时,这种引用关系也不能被破坏,这就是引用完整性,它的作用是确保在所有表中具有相同意义的字段值一致,不能引用不存在的值。引用完整性的实施方法是添加PRIMARY KEY 约束。...(2)数据的存储必须确保同一表格数据之间的和谐关系。例如,“成绩”表中的“学号”字段列中的每一个学号对应一个学生,不可能将其学号对应多个学生。 (3)数据的存储必须确保维护不同表之间的和谐关系。...注意:数据类型为IMAGE和 TEXT的字段列不能定义为主键。...执行完成之后,使用“DESC userinfo;,”语句查看表结构,执行结果如图5-10所示,从结果可以看出name字段和 tel字段组合在一起成为userinfo的多字段联合主键 3.4 删除表中的主键

    87420

    再见 MyBatis!我选择 JDBCTemplate!

    Hibernate和Mybatis是使用最多的两个主流框架,而JOOQ、Ebean等小众框架则知道的人不多,但也有很多独特的优点; 而JPA则是一组Java持久层Api的规范,Spring Data...不管是hibernate还是jpa,表之间的连接查询,被映射为实体类之间的关联关系,这样,如果两个实体类之间没有(实现)关联关系,你就不能把两个实体(或者表)join起来查询。...这里面最成功的应该是JOOQ,和QueryDSL不同,JOOQ的DSL编程是帮助开发人员编写SQL语句,抛弃累赘的ORM概念,JOOQ这个功能非常轻小,非常容易学习和使用,同时性能也非常好,不像QueryDSL...Ebean如果不使用原生SQL,而是使用JPA的方式开发,也能在不同数据库中平滑的移植。 MyBatis和JOOQ直接使用SQL,跨数据库移植时都难免要修改SQL语句。...相对于JOOQ,MyBatis在多数情况下没有任何优势。 Ebean同时具有很多不同框架的优点,但它是基于JPA的,难免有JPA的各种限制,这是致命的缺点。

    2.8K40

    这是我见过最有用的Mysql面试题,面试了无数公司总结的(内附答案)

    可以在一个列或一组列上创建索引。 18.所有不同类型的索引是什么? 索引有三种类型 1.唯一索引:唯一索引通过确保表中没有两行数据具有相同的键值来帮助维护数据完整性。...在SQL Server中,数据库表中的每一列都有一个名称和一种数据类型。 在创建SQL表时,我们需要决定在表的每一列中存储哪种数据类型。 57.可以在BOOLEAN数据字段中存储哪些可能的值?...Union和Union All都将两个表的结果连接在一起,但是这两个查询处理重复表的方式不同。 联合:省略重复的记录,仅返回两个或多个select语句的不同结果集。...假定:表1有10条记录,表2 有10条记录。两个表中的最后一条记录是相同的。 如果运行联合查询。...SELECT * FROM Table1UNION ALLSELECT * FROM Table2 输出:共20条记录 两个表中所有列的数据类型应相同。 66.

    27.1K20

    放弃 MyBatis、JPA,我最终选择了 JDBC Template!真香!!

    Hibernate和Mybatis是使用最多的两个主流框架,而JOOQ、Ebean等小众框架则知道的人不多,但也有很多独特的优点。...不管是hibernate还是jpa,表之间的连接查询,被映射为实体类之间的关联关系,这样,如果两个实体类之间没有(实现)关联关系,你就不能把两个实体(或者表)join起来查询。...这里面最成功的应该是JOOQ,和QueryDSL不同,JOOQ的DSL编程是帮助开发人员编写SQL语句,抛弃累赘的ORM概念,JOOQ这个功能非常轻小,非常容易学习和使用,同时性能也非常好,不像QueryDSL...Ebean如果不使用原生SQL,而是使用JPA的方式开发,也能在不同数据库中平滑的移植。 MyBatis和JOOQ直接使用SQL,跨数据库移植时都难免要修改SQL语句。...相对于JOOQ,MyBatis在多数情况下没有任何优势。 Ebean同时具有很多不同框架的优点,但它是基于JPA的,难免有JPA的各种限制,这是致命的缺点。

    3.4K10

    放弃MyBatis!我选择 JDBCTemplate!

    Hibernate和Mybatis是使用最多的两个主流框架,而JOOQ、Ebean等小众框架则知道的人不多,但也有很多独特的优点;而JPA则是一组Java持久层Api的规范,Spring Data JPA...不管是hibernate还是jpa,表之间的连接查询,被映射为实体类之间的关联关系,这样,如果两个实体类之间没有(实现)关联关系,你就不能把两个实体(或者表)join起来查询。...这里面最成功的应该是JOOQ,和QueryDSL不同,JOOQ的DSL编程是帮助开发人员编写SQL语句,抛弃累赘的ORM概念,JOOQ这个功能非常轻小,非常容易学习和使用,同时性能也非常好,不像QueryDSL...Ebean如果不使用原生SQL,而是使用JPA的方式开发,也能在不同数据库中平滑的移植。 MyBatis和JOOQ直接使用SQL,跨数据库移植时都难免要修改SQL语句。...相对于JOOQ,MyBatis在多数情况下没有任何优势。 Ebean同时具有很多不同框架的优点,但它是基于JPA的,难免有JPA的各种限制,这是致命的缺点。

    15710

    ClickHouse(02)ClickHouse架构设计介绍概述与ClickHouse数据分片设计

    DataTypeIDataType 负责序列化和反序列化:读写二进制或文本形式的列或单个值构成的块。IDataType直接与表的数据类型相对应。...不同的数据类型在内存中能够用相同的IColumn实现来表示。...另外,相同的数据类型也可以用不同的IColumn实现来表示。比如,DataTypeUInt8既可以使用ColumnUInt8 来表示,也可以使用过ColumnConstUInt8 来表示。...如果我们有一个Block,那么就有了数据(在IColumn对象中),有了数据的类型信息告诉我们如何处理该列,同时也有了列名(来自表的原始列名,或人为指定的用于临时计算结果的名字)。...注意,对于相同类型的计算,列名和类型对不同的块保持相同,仅列数据不同。

    45810

    再见!Mybatis,你好!JDBCTemplate

    Hibernate和Mybatis是使用最多的两个主流框架,而JOOQ、Ebean等小众框架则知道的人不多,但也有很多独特的优点;而JPA则是一组Java持久层Api的规范,Spring Data JPA...不管是hibernate还是jpa,表之间的连接查询,被映射为实体类之间的关联关系,这样,如果两个实体类之间没有(实现)关联关系,你就不能把两个实体(或者表)join起来查询。...这里面最成功的应该是JOOQ,和QueryDSL不同,JOOQ的DSL编程是帮助开发人员编写SQL语句,抛弃累赘的ORM概念,JOOQ这个功能非常轻小,非常容易学习和使用,同时性能也非常好,不像QueryDSL...Ebean如果不使用原生SQL,而是使用JPA的方式开发,也能在不同数据库中平滑的移植。 MyBatis和JOOQ直接使用SQL,跨数据库移植时都难免要修改SQL语句。...相对于JOOQ,MyBatis在多数情况下没有任何优势。 Ebean同时具有很多不同框架的优点,但它是基于JPA的,难免有JPA的各种限制,这是致命的缺点。

    3.9K10

    一、数据库表设计规范「建议收藏」

    2.第二范式 确保表中的每列都和主键相关 每个表只描述一件事 主要针对联合主键而言,不存在部分依赖,每一列都跟联合主键有关系,而与联合主键中的其中一个键无关系 比如要设计一个订单信息表,因为订单中可能会有多种商品...,所以要将订单编号和商品编号作为数据库表的联合主键,如下表所示。...如果要获取订单的商品信息,使用商品编号到商品信息表中查询即可。 3.第三范式 确保每列都和主键列直接相关,而不是间接相关,不存在传递依赖。...(5)不同表之间存储相同数据的列名和列类型必须一致(关联列) (6)优先选择符合存储需要的最小、最简单的数据类型。...(4)限制每张表的索引数量,建议每张表的索引数量不超过5个,并且针对复合索引,最常用的、区分度最高的(列中不同值数量/列的总行数)、字段长度小的放到最左侧 (5)索引列定义为 not null 索引null

    2.8K20

    另一种思考:为什么不选JPA、MyBatis,而选择JDBCTemplate?

    Hibernate和Mybatis是使用最多的两个主流框架,而JOOQ、Ebean等小众框架则知道的人不多,但也有很多独特的优点;而JPA则是一组Java持久层Api的规范,Spring Data JPA...不管是hibernate还是jpa,表之间的连接查询,被映射为实体类之间的关联关系,这样,如果两个实体类之间没有(实现)关联关系,你就不能把两个实体(或者表)join起来查询。...这里面最成功的应该是JOOQ,和QueryDSL不同,JOOQ的DSL编程是帮助开发人员编写SQL语句,抛弃累赘的ORM概念,JOOQ这个功能非常轻小,非常容易学习和使用,同时性能也非常好,不像QueryDSL...Ebean如果不使用原生SQL,而是使用JPA的方式开发,也能在不同数据库中平滑的移植。 MyBatis和JOOQ直接使用SQL,跨数据库移植时都难免要修改SQL语句。...相对于JOOQ,MyBatis在多数情况下没有任何优势。 Ebean同时具有很多不同框架的优点,但它是基于JPA的,难免有JPA的各种限制,这是致命的缺点。

    2.6K20

    数据库字段及索引设计规范

    建议把 BLOB 或是 TEXT 列分离到单独的扩展表中 MySQL 内存临时表不支持 TEXT、BLOB 这样的大数据类型,如果查询中包含这样的数据,在排序等操作时,就不能使用内存临时表,必须使用磁盘临时表进行...禁止给表中的每一列都建立单独的索引 5.6 版本之前,一个 sql 只能使用到一个表中的一个索引,5.6 以后,虽然有了合并索引的优化方式,但是还是远远没有使用一个联合索引的查询方式好。 3....每个 Innodb 表必须有个主键 Innodb 是一种索引组织表:数据的存储的逻辑顺序和索引的顺序是相同的。每个表都可以有多个索引,但是表的存储顺序只能有一种。...Innodb 是按照主键索引的顺序来组织表的 不要使用更新频繁的列作为主键,不适用多列主键(相当于联合索引) 不要使用 UUID,MD5,HASH,字符串列作为主键(无法保证数据的顺序增长) 主键建议使用自增...区分度最高的放在联合索引的最左侧(区分度=列中不同值的数量/列的总行数) 尽量把字段长度小的列放在联合索引的最左侧(因为字段长度越小,一页能存储的数据量越大,IO 性能也就越好) 使用最频繁的列放到联合索引的左侧

    1.1K20

    MySQL 系列教程之(四)MySQL 中的数据类型

    例如,数值数据类型列只能接受数值类型的的数据 在设计表时,应该特别重视所用的数据类型。使用错误的数据类型可能会严重地影响应用程序的功能和性能。...不管使用何种形式的串数据类型,串值都必须括在引号内 有两种基本的串类型,分别为定长串和变长串 定长串:CHAR 接受长度固定的字符串,其长度是在创建表时指定的。...[在这里插入图片描述] --- 2、数值类型 数值数据类型存储数值。MySQL支持多种数值数据类型,每种存储 的数值具有不同的取值范围。...中没有专门存储货币的数据类型,一般情况下使用DECIMAL(8, 2) 有符号或无符号 所有数值数据类型(除BIT和BOOLEAN外)都可以有符号或无符号 有符号数值列可以存储正或负的数值 无符号数值列只能存储正数...,_表示任意一位字符 --- 四、主键 1、表中每一行都应该有可以唯一标识自己的一列,用于记录两条记录不能重复,任意两行都不具有相同的主键值 2、应该总是定义主键 虽然并不总是都需要主键,但大多数数据库设计人员都应保证他们创建的每个表具有一个主键

    1.6K83

    值得收藏:一份非常完整的 MySQL 规范

    (时间戳)为后缀 · 所有存储相同数据的列名和列类型必须一致(一般作为关联列,如果查询时关联列类型不一致会自动进行数据类型隐式转换,会造成列上的索 引失效,导致查询效率降低) 二、数据库基本设计规范 1...表必须有个主键 Innodb是一种索引组织表:数据的存储的逻辑顺序和索引的顺序是相同的。...,通常将1、2中的字段建立联合索引效果更好 · 多表join的关联列 六、如何选择索引列的顺序 建立索引的目的是:希望通过索引进行数据查找,减少随机IO,增加查询性能 ,索引能过滤出越少的数据,则从磁盘中读入的数据也就越少...· 区分度最高的放在联合索引的最左侧(区分度=列中不同值的数量/列的总行数); · 尽量把字段长度小的列放在联合索引的最左侧(因为字段长度越小,一页能存储的数据量越大,IO性能也就越好); · 使用最频繁的列放到联合索引的左侧...4、数据库设计时,应该要对以后扩展进行考虑 5、程序连接不同的数据库使用不同的账号,进制跨库查询 · 为数据库迁移和分库分表留出余地 · 降低业务耦合度 · 避免权限过大而产生的安全风险 6、禁止使用SELECT

    90130

    值得收藏:一份非常完整的 MySQL 规范

    ,并且最后不要超过32个字符 · 临时库表必须以tmp_为前缀并以日期为后缀,备份表必须以bak_为前缀并以日期(时间戳)为后缀 · 所有存储相同数据的列名和列类型必须一致(一般作为关联列,如果查询时关联列类型不一致会自动进行数据类型隐式转换...兼容性更好,统一字符集可以避免由于字符集转换产生的乱码,不同的字符集进行比较前需要进行转换会造成索引失效 3、所有表和字段都需要添加注释 使用comment从句添加表和列的备注 从一开始就进行数据字典的维护...,通常将1、2中的字段建立联合索引效果更好 · 多表join的关联列 六、如何选择索引列的顺序 建立索引的目的是:希望通过索引进行数据查找,减少随机IO,增加查询性能 ,索引能过滤出越少的数据,则从磁盘中读入的数据也就越少...· 区分度最高的放在联合索引的最左侧(区分度=列中不同值的数量/列的总行数); · 尽量把字段长度小的列放在联合索引的最左侧(因为字段长度越小,一页能存储的数据量越大,IO性能也就越好); · 使用最频繁的列放到联合索引的左侧...4、数据库设计时,应该要对以后扩展进行考虑 5、程序连接不同的数据库使用不同的账号,进制跨库查询 · 为数据库迁移和分库分表留出余地 · 降低业务耦合度 · 避免权限过大而产生的安全风险 6、禁止使用SELECT

    97330

    值得收藏:一份非常完整的 MySQL 规范

    (时间戳)为后缀 · 所有存储相同数据的列名和列类型必须一致(一般作为关联列,如果查询时关联列类型不一致会自动进行数据类型隐式转换,会造成列上的索 引失效,导致查询效率降低) 二、数据库基本设计规范 1...表必须有个主键 Innodb是一种索引组织表:数据的存储的逻辑顺序和索引的顺序是相同的。...,通常将1、2中的字段建立联合索引效果更好 · 多表join的关联列 六、如何选择索引列的顺序 建立索引的目的是:希望通过索引进行数据查找,减少随机IO,增加查询性能 ,索引能过滤出越少的数据,则从磁盘中读入的数据也就越少...· 区分度最高的放在联合索引的最左侧(区分度=列中不同值的数量/列的总行数); · 尽量把字段长度小的列放在联合索引的最左侧(因为字段长度越小,一页能存储的数据量越大,IO性能也就越好); · 使用最频繁的列放到联合索引的左侧...4、数据库设计时,应该要对以后扩展进行考虑 5、程序连接不同的数据库使用不同的账号,进制跨库查询 · 为数据库迁移和分库分表留出余地 · 降低业务耦合度 · 避免权限过大而产生的安全风险 6、禁止使用SELECT

    76230

    Mysql_基础

    例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应 使用下面语句格式加以限定: 复制内容到剪贴板 代码:SELECT `username`,citytable.cityid...要对联合查询结果排序时,也必须使用第一查询语句中的列名、列标题或者列序号。...在使用UNION 运算符时,应保证每个联合查询语句的选择列表中有相同数量的表达式,并且每个查询选 择表达式应具有相同的数据类型,或是可以自动将它们转换为相同的数据类型。...当检索数据时,通过连接操作查询出存放在多个表中的不同实体的信息。连接操作给用户带 来很大的灵活性,他们可以在任何时候增加新的数据类型。为不同实体创建新的表,尔后通过连接进行 查询。...根据所使用的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。

    2.4K70
    领券