时间:2021-07-01 10:21:17 帮助过:18人阅读
MySQL在查询字符串时是大小写不敏感的,在编绎MySQL时一般以ISO-8859字符集作为默认的字符集,这个字符集对大小写不敏感,因此在比较过程中中文编码字符大小写转换造成了这种现象。
2.解决办法
A.表名区分大小写
在my.conf加入:
ower_case_table_names = 0
其中 0:区分大小写,1:不区分大小写
B.插入查询时区分大小写
字段值需要设置BINARY属性,即可区分大小写。
设置的方法有多种:
创建时设置:
CREATE TABLE T(
A VARCHAR(10) BINARY
);
使用alter修改:
ALTER TABLE `tablename` MODIFY COLUMN `cloname` VARCHAR(45) BINARY;
mysql table editor中直接勾选BINARY项。
oracle中分为两种情况,单纯的sql语句不区分大小写,但是如果查询某个字符的话就需要区分大小写。
1、如以下情况,是不区分大小写的,查询结果都是一致的:
select * from emp;
SELECT * FROM EMP;
|
2、如在emp表中查询ename为“SMITH”(不含引号)的信息,就必须注意大小写:
select * from emp where ename= ‘SMITH‘ ;
|
这样是有结果的,如图:
select * from emp where ename= ‘smith‘ ;
|
这样则查询不出结果:
MYSQL和oracle 大小写问题
标签:ora 比较 tle har bin like arch 过程 .com