Sql 中Collate用法】的更多相关文章

今天查询sqlite的时候需要不区分大小写,查了下文档,需要使用collate nocase.顺便学习下collate的用法. collate在sql中是用来定义排序规则的.排序规则其实就是当比较两个字符串时,根据某种规则来确定哪个比较大,是否相等.各个数据库支持不同的排序规则. sqlite有三种build in的排序规则: BINARY 二进制比较,直接使用memcmp()比较 NOCASE  将26个大写字母转换为小写字母后进行与BINARY一样的比较 RTRIM  和BINARY一样,忽…
SQL 中ROLLUP 用法 ROLLUP 运算符生成的结果集类似于 CUBE 运算符生成的结果集. 下面是 CUBE 和 ROLLUP 之间的具体区别: CUBE 生成的结果集显示了所选列中值的所有组合的聚合. ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合. ROLLUP 优点: (1)ROLLUP 返回单个结果集,而 COMPUTE BY 返回多个结果集,而多个结果集会增加应用程序代码的复杂性. (2)ROLLUP 可以在服务器游标中使用,而 COMPUTE BY 则不可以…
SQL中EXISTS的用法   比如在Northwind数据库中有一个查询为SELECT c.CustomerId,CompanyName FROM Customers cWHERE EXISTS(SELECT OrderID FROM Orders o WHERE o.CustomerID=c.CustomerID) 这里面的EXISTS是如何运作呢?子查询返回的是OrderId字段,可是外面的查询要找的是CustomerID和CompanyName字段,这两个字段肯定不在OrderID里面啊…
在写sql中去重复等操作,需要用到distinct. 在使用distinct的时候要注意,尤其是在有行列转换的时候.要把sql运行出来看看是不是与你想要的结果一样. 通过自己试验,distinct有从小到大排序的作用. create table ProvinceName(PID int,PName varchar(20)) insert into ProvinceNamevalues(1,'a') insert into ProvinceNamevalues(3,'b') insert into…
CHARINDEX作用 写SQL语句我们经常需要判断一个字符串中是否包含另一个字符串,但是SQL SERVER中并没有像C#提供了Contains函数,不过SQL SERVER中提供了一个叫CHAEINDX的函数,顾名思义就是找到字符(char)的位置(index),既然能够知道所在的位置,当然就可以判断是否包含在其中了. 通过CHARINDEX如果能够找到对应的字符串,则返回该字符串位置,否则返回0. 基本语法如下: CHARINDEX ( expressionToFind , express…
DATEDIFF 函数 [日期和时间] 功能返回两个日期之间的间隔. 语法DATEDIFF ( date-part, date-expression-1, date-expression-2 ) date-part :year | quarter | month | week | day | hour | minute | second | millisecond 参数date-part 指定要测量其间隔的日期部分. 有关日期部分的详细信息,请参见日期部分. date-expression-1…
ISNULLSQL查询示例SELECT ISNULL    使用指定的替换值替换 NULL. 语法       :ISNULL ( check_expression , replacement_value ) 参数    check_expression  将被检查是否为 NULL的表达式.如果不为NULL,这直接返回 该值,也就是 check_expression 这个表达式.如果为空这个直接返回 replacement_value这个表达的内容....check_expression 可以是…
for c in (select column_value from table(f_split(V_FileID, ','))) loop --若没有填写资格开始结束时间,则填入 select count(*) into numDataCount from ly_zg_jzfbt z where file_id = c.column_value and z.pt_valid_stime is null; then update ly_zg_jzfbt z set z.pt_valid_stim…
现在 Student表有 如下数据 现需求如下: 查找每个老师的学生的平均年龄且平均年齿大于12 不使用 HAVING SELECT * FROM (SELECT TeacherID, AVG(Age) AS AGE FROM Student 使用HAVING SELECT TeacherID, AVG(Age) AS AGE FROM Student GROUP BY TeacherID 结果如下: HAVING:给分组设置条件…
"between xx and  xx "在SQL中的用法 这个大家都很熟悉,但是当问到是否包含两端的值时,就有点儿不确定了.在W3School网站上,有这样的一段话: 参考:http://www.w3school.com.cn/sql/sql_between.asp 所以,根据w3school的说法,不同数据库对该操作边界值的处理不同.…