新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
//查询表中的数据 同时某个字段不重复 并且排序
创新互联公司专注于企业成都营销网站建设、网站重做改版、石棉网站定制设计、自适应品牌网站建设、HTML5建站、商城网站开发、集团公司官网建设、外贸网站制作、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为石棉等各大城市提供网站开发制作服务。
首先做一下查询某个字段不重复(使用group by);
select * from 表名 where group by 不重复的字段名;
在做一下排序,我之前有发过一次排序,这次就做一个简单排序
order by 字段a=0 desc, 字段a desc,字段b desc (a字段等于0在最前面,a字段除了0之外的都为倒叙,b字段倒叙);
这样组合起来就好了
select * from 表名 where group by 不重复的字段名 order by 字段a=0 desc, 字段a desc,字段b desc;
需求说明
1、我需要查询某列不重复的数据
2、并且显示不重复数据的所有项
sql语句如下
select * from data group by address;
如果是仅仅查询某列不重复数据,只需要一列
效果如下
sql语句
select DISTINCT address from data
这里有一个非常非常需要注意的地方:
SELECT DISTINCT [字段名]后面不能再跟其他的字段,否则检索出来的记录仍然会含有重复项;
错误写法:
SELECT DISTINCT [字段名] ,[其他字段名] FROM [表名] WHERE [检索条件字句]
如果我们的记录集里还需要有其他字段值 ,那怎么办呢?
实际上,我们完全可以用另一种办法来解决问题;只是需要用到子查询而已!
使用GROUP BY 分组
有一点需要注意:
使用带有GROUP BY字句的查询语句时,在SELECT列表指定的列要么是GROUP BY 指定的列,要么包含聚合组函数
所以用这样一句SQL就可以去掉重复项了:
select * from msg group by terminal_id;
这样就得到我们想要的结果集了:
1、使用navicat连接上mysql数据库,新建一张用户表。
2、然后填入几条测试内容,来演示测试效果。
2、选中用户名右击选择设计表。
3、然后在设计表里切换到索引选项卡。
4、这一步开始添加一条索引,如果对索引名称没有要求可以默认为空,工具会自动帮生成和字段名一样的名称。点击栏位后面的按钮出现选择框,选择需要唯一约束的字段,这里我们登录名字段。
5、索引类型选择,这里是关键,唯一性约束一定要选择Unique类型。
6、最后添加完成唯一索引之后,修改下第三条数据的登录名为bb和第二条一样,然后点击下方对号按钮,进行保存
7、此时保存时候就会报错,提示"Duplicate entry 'bb' for key 'login_name'",重复的登录名,不能保存成功,说明添加的唯一性约束生效了。
MySQL查询重复字段,及删除重复记录的方法
数据库中有个大表,需要查找其中的名字有重复的记录id,以便比较。如果仅仅是查找数据库中name不重复的字段,很容易:
SELECT min(`id`),`name` FROM `table` GROUP BY `name`;
但是这样并不能得到说有重复字段的id值。(只得到了最小的一个id值)查询哪些字段是重复的也容易:
SELECT `name`,count(`name`) as count FROM `table` GROUP BY `name` HAVING count(`name`) 1 ORDER BY count DESC;
但是要一次查询到重复字段的id值,就必须使用子查询了,于是使用下面的语句。
SELECT `id`,`name` FROM `table` WHERE `name` in (
SELECT `name`
FROM `table`
GROUP BY `name` HAVING count(`name`) 1);
但是这条语句在mysql中效率太差,感觉mysql并没有为子查询生成零时表。于是使用先建立零时表:
create table `tmptable` as (
SELECT `name`
FROM `table`
GROUP BY `name` HAVING count(`name`) 1);
//id 替换成日期 name 人名
select name from test2 where id=5 and name not in(select name from test2 where id!=5)