在sqlite3中查询
1、有如下sql语句: select count(*) from jcjg where ( date(substr(jcsj,1,4)||"-"||substr(jcsj,5,2)||"-"||substr(jcsj,7,2)) between date("2015-05-29") and date("2015-06-01") ); 2、从网上查询得知,substr是oracle语法中的。如下所示;
c)、to_date(str,'yyyymm') 将str(字符型)转换为日期类型 字符的格式为yyyymm
3、在sqlite中好像有点不同:
4、例子: 从win端打开sqlite数据库,然后jcjg表的结构如图所示:
然后执行如下sql语句: select count(*) from jcjg where ( date(substr(jcsj,2)) between date("2015-05-29") and date("2015-06-01") ); 数据库中显示的结果为:
5、如果between后面的时间格式和前面的格式不相同,sql语句执行完后,显示的结果count(*)列为0。 如图所示: 6、SQL函数substr使用简介:substr(string,start,length) string - 指定的要截取的字符串。start - 必需,规定在字符串的何处开始。正数 - 在字符串的指定位置开始,负数 - 在从字符串结尾的指定位置开始,0 - 在字符串中的第一个字符处开始。length - 可选,指定要截取的字符串长度,缺省时返回字符表达式的值结束前的全部字符。 例如:select substr('abcdefg',3,4) from dual; 结果是cdef select substr('abcdefg',-3,4) from dual; 结果efg 注意:字符串中的第一个位置始终为1。以下两个sql查询的结果相同: 例如:select substr('abcdefg',3) from dual; 结果是abc select substr('abcdefg',3) from dual; 结果是abc 7、与java类中的substring区别: substring(int beginIndex,int endIndex) :从指定的 beginIndex 处开始,到指定的 endIndex-1处结束,字符串中的第一个位置始终为0。endIndex,可选,缺省时返回始于指定索引处的字符,一直到此字符串末尾。 例如:"unhappy".substring(2) returns "happy" "hamburger".substring(3,8) returns "burge" ?? ??(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |