尽管看到问题年代有点久远,但我觉得有必要纠正一下:
在表结构中,username 字段类型为varchar 即字符串型,而非整数型
那么查询语句,用到username = *** 时,必须写成 username ='***' ,比如: username = '0',再比如 username = 'admin'
而如果写成 username = 0呢? 0是一个整数型,那么
数据库中username字段的数据类型会被强制转化为整型,然后再与0进行匹配.即 admin会转化为0 (因为是a开头,而非数字开头),同理,test也会转为0, 再比如110test会转化为110,再比如 0admin会转化为0 ....
再看我的图片1的例子:
select username from t_user where username = 0-- 图片左边的结果
select username from t_user -- 图片右边的结果
再看我的图片2的例子:
select username from t_user where username =4241101
其中一个当然可以,但如果你这几个条件经常需要组合使用,那么建立联合索引的效率会更高。但建立联合索引的话,你如果只用到了其中的部分条件,那么必须遵守最左原则,比如说建立索引ABC 那么你用A,AB,ABC都可用到该索引,但是如果查B,BC,则无法用到,查AC的话应该是只能用到A部分的索引
这个不是错在加了and就报错,应该是错在没有指定查那个表。
这个应该是存在多个表中都有sno字段,所以需要给该字段指定表名。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)