今天工作时写了一个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. C# 类型转换 Dictionary转Model类

    /// <summary> /// 把Model转换为DataRow /// </summary> /// <typeparam name="T"&g ...

  2. RegisterStartupScript和RegisterClientScriptBlock的区别

    1.  //注册到 <form> 尾部 ,HTML元素已加载完毕    this.Page.ClientScript.RegisterStartupScript(this.GetType( ...

  3. 类名 对象名 =new 类名();

    类名 对象名 =new 类名();该怎么理解 类名 对象名 =new 类名();=左边:创建一个类的对象=右边:调用这个类的构造函数初始化对象,类名()这个是构造函数,用来做初始化的.

  4. CentOS6 更改Mysql数据库的数据存放位置

    mysql使用yum安装时,默认的数据是存储在/var/lib/mysql下.一般情况下,为了数据的安全性,建议将mysql数据库的数据文件存储在系统的第二块磁盘上的目录下可以按照以下步骤进行操作: ...

  5. excute和query

    query(update goods set is_delete=1 where goods_id=13)总是出错??为什么, excute(update goods set is_delete=1 ...

  6. 基于jQuery打造的选项卡向上弹出jquery焦点图切换特效

    基于jQuery打造的选项卡向上弹出jquery焦点图切换特效 鼠标经过标题栏,会出现层特效向上滑动,并且在同时进行幻灯片切换,效果十分不错. 有兴趣的童鞋可以下载看看,在IE6方面兼容性也不错,只有 ...

  7. 一,U盘安装 CentOS 6.5 minimal

    U盘安装盘: CentOS-6.5的版本有四个,分别是: 1.CentOS-6.5-i386-netinstall.iso 通过网络安装的,需要联网 2.CentOS-6.5-i386-minimal ...

  8. 10-排序5 PAT Judge

    用了冒泡和插入排序 果然没有什么本质区别..都是运行超时 用库函数sort也超时 The ranklist of PAT is generated from the status list, whic ...

  9. SRF之页面

    页面呈现采用Razor模板   1.母模板说明 _Main.cshtml:基础母模板 _ListLayout.cshtml:列表页面 _EditDialog.cshtml:编辑对话框 _EditLay ...

  10. java 网页页面抓取标题和正文

    import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import ...