今天工作时写了一个sql,但是PostgreSQL总是提示有语法错误,简单的做个记录:

 问题1、'' 和“”单引号和双引号

        举个例子:
    

  #1、select id, delivery_date, sal_plan_date from zaiko_shop where id="";
#2、select id, delivery_date, sal_plan_date from zaiko_shop where id='';
上面的两句sql中不同的知识#1用的是双引号,#2用的是单引号
        但是#1却会报错:
    
 上面的这个问题就提示我们在写sql语句时尽量这样做:
        最外面的使用双引号,表示拼接一个sql语句,sql语句中的字符串条件使用单引号
        $sql = "select id, delivery_date, sal_plan_date from zaiko_shop where id='' "
问题2、null 和 ''
举个例子:

   SELECT COUNT(*) AS adv_num
FROM zaiko_shop
WHERE delivery_date!=null
AND sal_plan_date != null
AND to_char(delivery_date,'YYYY-MM') != to_char(sal_plan_date,'YYYY-MM')
AND shop_id=1031
AND del_flag=0
AND sal_plan_date BETWEEN '2014-01-01' AND '2014-12-31';
  首先就是对于这个date类型的日期判断为空? 
        上面的这种写法是错误的,翻到一些以前学习mysql是的笔记,可以做个参考,毕竟都是sql 相同的地方还是有很多的
              首先,我们应该清楚 : null 和 ‘’的区别?
                     ‘’相当于你在银行办理了一张银行卡,只是里面没有钱而已
                     null 相当于你就根本没有办理银行卡,一些基本的描述信息都是没有的
              其次,对于 sal_plan_date != null 这里的 !=null
                null是一种类型,比较时只能使用专门的 is null 或者 is not null来比较
                     碰到运算符,一律返回null,比如 :where name!=null,这样是得不到我们期望的数据的或者说得不到正确的数据的

  所以,上面的这种写法是错误的,上面的虽然是小问题,但是有时候就是这些小问题,让我们‘很上头’,所以,平时规范的使用,可以避免很多麻烦的事情。也会让我们少去很多头疼的时间,要不然,桌子上的头发看的自己都伤心,以前觉得那些程序员秃顶是胡扯,现在感觉这个确实有可能,因为我平时很烦的时候就后揪头发,哎、、、所以,规范的编写帮助我们在不知不觉中就能减少很多的麻烦!
     做个记录,希望能够帮到别人!
 
 

PostgreSQL中的引号和null的更多相关文章

  1. Postgresql中的数据类型大全

    一.数值类型: 下面是PostgreSQL所支持的数值类型的列表和简单说明: 名字 存储空间 描述 范围 smallint 2 字节 小范围整数 -32768 到 +32767 integer 4 字 ...

  2. PostgreSQL 中日期类型转换与变量使用及相关问题

    PostgreSQL中日期类型与字符串类型的转换方法 示例如下: postgres=# select current_date; date ------------ 2015-08-31 (1 row ...

  3. PostgreSQL 中定义自己需要的数据类型

    PostgreSQL解决某系数据库中的tinyint数据类型问题,创建自己需要的数据类型如下: CREATE DOMAIN tinyint AS smallint CONSTRAINT tinyint ...

  4. 用python随机生成数据,再插入到postgresql中

    用python随机生成学生姓名,三科成绩和班级数据,再插入到postgresql中. 模块用psycopg2 random import random import psycopg2 fname=[' ...

  5. PostgresQL中的NUlls first/last功能

    Nulls first/last功能简介Nulls first/last功能主要用于order by排序子句中,影响空值Null在排序结果中的位置.简单来说,Nulls first表示Null值在排序 ...

  6. PostgreSQL中的索引(一)

    引言 这一系列文章主要关注PostgreSQL中的索引. 可以从不同的角度考虑任何主题.我们将讨论那些使用DMBS的应用开发人员感兴趣的事项:有哪些可用的索引:为什么会有这么多不同的索引:以及如何使用 ...

  7. PostgreSQL中实现更新默认值(二)

    今天我们用表继承+触发器的方案,来实现表中的更新默认值.这也许是PostgreSQL里最佳的解决方案. 一. 创建一张表,作为父表 create table basic_update( t_updat ...

  8. 通过arcgis在PostgreSQL中创建企业级地理数据库

    部署环境: Win7 64位旗舰版 软件版本: PostgreSQL-9.1.3-2-windows-x64 Postgis-pg91x64-setup-2.0.6-1 Arcgis 10.1 SP1 ...

  9. include包含头文件的语句中,双引号和尖括号的区别是什么?

    include包含头文件的语句中,双引号和尖括号的区别是什么?  #include <> 格式:引用标准库头文件,编译器从标准库目录开始搜索 尖括号表示只在系统默认目录或者括号内的路径查找 ...

随机推荐

  1. IIS URL重写找不到页面 (URLRewriter.dll伪静态)

    在网站上点右键 属性 进入主目录菜单 点击配置 找到.html扩展名 编辑 将 检查文件是否存在 的钩去掉! OK

  2. javaSE第三天

    第三天    12 1:运算符(掌握)    12 (1)算术运算符    12 (2)赋值运算符    12 (3)比较运算符    13 (4)逻辑运算符    13 (5)位运算符(了解)    ...

  3. ASP.NET中Server对象的几个方法

    HtmlDecode 已重载. 对已被编码以消除无效 HTML 字符的字符串进行解码.HtmlEncode 已重载. 对要在浏览器中显示的字符串进行编码.MapPath 返回与 Web 服务器上的指定 ...

  4. c语言学习的第6天

    #include <stdio.h> int main() { int x=100; if(x==0) { printf("x等于0\n"); printf(" ...

  5. FileOutputSream

    package cd.itcast.fileinputstream; import java.io.File; import java.io.FileNotFoundException; import ...

  6. 19.python的编码问题

    在正式说明之前,先给大家一个参考资料:戳这里 文章的内容参考了这篇资料,并加以总结,为了避免我总结的不够完善,或者说出现什么错误的地方,有疑问的地方大家可以看看上面那篇文章. 以下说明是针对于pyth ...

  7. 一幅图证明chrome的由来和目的

  8. openshift云计算平台diy模式安装Python2.7+Flask

    主要翻译了链接1)的教程,加上一些个人研究,步骤如下: 1) 在openshift.redhat.com申请账号,安装git for windows,然后安装gem install rhc,这些比较容 ...

  9. open/fopen read/fread write/fwrite区别

    fopen /open区别 UNIX环境下的C 对二进制流文件的读写有两套班子:1) fopen,fread,fwrite ; 2) open, read, write这里简单的介绍一下他们的区别.1 ...

  10. ED/EP系列2《文件结构》

    电子存折/电子钱包应用是为持卡人进行金融交易而设计的一种应用.对于一张金融 IC 卡来说,它可以同时支持电子存折和电子钱包两种应用,也可以只支持其中的一种.卡片上两种应用的存在情况可以由应用类型标识( ...