计算字段

  • 如果想在一个字段中既显示公司的名称,又显示公司的地址,但是这两个信息一般包含在不同的表列中
  • 城市、州和邮政编码存储在不同的列中,但是邮件标签打印程序却需要把它们作为一个恰当格式的字段检索出来
  • 物品订单表存储物品的价格和数量,但不需要存储每个物品的总价格,为了打印发票,需要物品的总价
  • 需要根据表数据进行总数、平均数计算或者其它计算

最近每天都在空闲时间努力编写Apworks澳门微尼斯人手机版,框架的案例代码WeText。在文本发布和处理微服务中,我打算使用微软的SQL
Server for Linux来做演示,于是也就在自己的docker-compose中加入了MS SQL
Server的服务。其实在Docker中运行SQL
Server是非常容易的,今天大概做个介绍吧。

前面的话

  查询数据库,当查询条件比较复杂时,常常需要用到子查询。子查询(Subquery)是指出现在其他SQL语句内的SELECT子句。本文将详细介绍子查询

 

拼接字段

例子:vendors表包含供应商名和位置信息。假如要生成一个供应商报表,需要在供应商的名字中按照name(location)这样的格式列出供应商信息。此报表需要单个值,而表中数据存储在两个列vend_name和vend_country中,此外,需要用括号将vend_country括起来,这些东西都没有明确存储在数据表中,我们来看看怎么样编写返回供应商名和位置的select语句

SELECT CONCAT(vend_name, ' (',vend_country,')') FROM vendors ORDER BY vend_name;

这里用到了concat函数,拼接串,即把多个串连接起来形成一个较长的串,concat需要一个或者多个指定的串,各个串之间用逗号分隔

澳门微尼斯人手机版 1

SELECT CONCAT(RTRIM(vend_name),' (',RTRIM(vend_country),')') FROM vendors ORDER BY vend_name;

rtrim函数去掉值右边的所有空格,通过使用rtrim(),各个列都进行了整理

澳门微尼斯人手机版 2

启动Microsoft SQL Server 2017容器

下面是我目前WeText案例中用于搭建基础结构服务的docker-compose.yml文件(该文件将来还会变动,最新版本请参阅Github):

version: "3"
services:
    mongodb:
        image: mongo
        volumes:
            - ${MONGODB_DATABASE_VOLUME}
        container_name: mongodb
        ports:
            - "27017:27017"
    rabbit:
        image: rabbitmq:3-management
        ports:
            - "5672:5672"
            - "4369:4369"
            - "5671:5671"
            - "25672:25672"
            - "15672:15672"
        container_name: rabbitmq
        hostname: my-rabbitmq
        volumes:
            - ${RABBITMQ_DATA_VOLUME}
    postgres:
        image: postgres
        ports:
            - "5432:5432"
        container_name: postgres
        volumes:
            - ${POSTGRESQL_DATA_VOLUME}

    mssql:
        image: microsoft/mssql-server-linux:2017-latest
        ports:
            - "1433:1433"
        container_name: mssql
        environment:
            - ACCEPT_EULA=Y
            - SA_PASSWORD=G1veMeP@ss

这个docker-compose文件中包含了四个服务的定义,今天我们只关注最后一个,也就是mssql。可以看到:

  1. Microsoft SQL
    Server的Docker镜像名为:microsoft/mssql-server-linux,tag为2017-latest
  2. SQL Server在容器内侦听1433端口,也就是标准的SQL Server端口
  3. 启动SQL
    Server容器需要两个环境变量:ACCEPT_EULA=Y,表示接受最终用户许可协议;SA_PASSWORD=G1veMeP@ss,表示设置sa用户的密码。这个用户密码要符合强密码规范(数字、字母、大小写,至少8个字符),之后在客户端连接的时候,就需要使用这个密码登录服务器

当然,你可以不使用docker-compose,而是直接使用docker
run,那么方法也是类似的,比如可以使用下面的语句:

sudo docker run -e 'ACCEPT_EULA=Y' -e 'SA_PASSWORD=G1veMeP@ss' \
   -p 1433:1433 --name mssql \
   -d microsoft/mssql-server-linux:2017-latest

同样也可以启动SQL Server容器。在Docker中运行SQL Server时,需要注意:

  1. 主机(host machine)的内存至少需要3.5GB左右
  2. Docker中的SQL Server是开发者版本(Developer
    Edition),功能与企业版相同,但是仅能用于开发或者测试环境,不得用于生产环境

定义

  子查询(Subquery)是指出现在其他SQL语句内的SELECT子句

SELECT * FROM t1 WHERE col1 = (SELECT col2 FROM t2);

  其中,SELECT * FROM t1,称为外层查询(Outer Query/Outer
Statement),SELECT col2 FROM t2,称为子查询(SubQuery)

  在使用子查询时,需要注意的是

  1、子查询指嵌套在查询内部,且必须始终出现在圆括号内

  2、子查询语句中可以包含多个关键字或条件,如DISTINCT、GROUP BY、ORDER
BY、LIMIT、函数等

  3、子查询的外层查询可以是:SELECT、INSERT、UPDATE、SET或DO

  4、子查询返回值可以是:标量、一行、一列或者子查询

 

发表评论

电子邮件地址不会被公开。 必填项已用*标注