以下sql存在多条一样的general_master_type_nm数据,怎么修改呢? WITH -- 表示権限区分が0の汎用マスタ区分を洗い出す a1 AS ( SELECT DISTINCT GENERAL_MASTER_TYPE, DISPLAY_AUTH_CLS AS displayAuthCls FROM m_general WHERE DISPLAY_AUTH_CLS = '0' ), -- 更新権限区分が0の汎用マスタ区分を洗い出す a2 AS ( SELECT DISTINCT GENERAL_MASTER_TYPE, UPD_AUTH_CLS AS updAuthCls FROM m_general WHERE UPD_AUTH_CLS = '0' ), b AS ( SELECT GENERAL_MASTER_TYPE, GENERAL_MASTER_TYPE_NM, MIN( DISPLAY_AUTH_CLS ) AS displayAuthCls, MIN( UPD_AUTH_CLS ) AS updAuthCls FROM m_general GROUP BY GENERAL_MASTER_TYPE, GENERAL_MASTER_TYPE_NM ),-- a と bを合併した最小表示権限区分 c AS ( SELECT b.GENERAL_MASTER_TYPE, b.GENERAL_MASTER_TYPE_NM, IFNULL ( a1.displayAuthCls, b.displayAuthCls ) AS displayAuthCls, IFNULL ( a2.updAuthCls, b.updAuthCls ) AS updAuthCls FROM b LEFT JOIN a1 ON b.GENERAL_MASTER_TYPE = a1.GENERAL_MASTER_TYPE LEFT JOIN a2 ON b.GENERAL_MASTER_TYPE = a2.GENERAL_MASTER_TYPE ) -- 抽出結果 SELECT DISTINCT (mg.GENERAL_MASTER_TYPE), mg.GENERAL_MASTER_TYPE_NM, c.updAuthCls, c.displayAuthCls, #{authority.slpmAuthCls} as slpmAuthCls FROM m_general mg INNER JOIN c ON mg.GENERAL_MASTER_TYPE = c.GENERAL_MASTER_TYPE AND (c.displayAuthCls <![CDATA[ <> '0']]> OR ( #{authority.slpmAuthCls} = '0' AND #{authority.levelType} ='1') ) WHERE 1 = 1 <if test="!containsDel"> and mg.del_flg <![CDATA[ <> '1']]> </if> ORDER BY mg.GENERAL_MASTER_TYPE_NM ASC </select>

时间: 2023-06-07 17:10:14 浏览: 32
可以使用UPDATE语句来修改数据库中的数据。可以使用GROUP BY语句来将重复的数据进行合并,使用MAX或MIN函数选择其中一个来保留一个唯一的值。例如,可以这样编写一个UPDATE语句: UPDATE m_general SET DISPLAY_AUTH_CLS = MIN(DISPLAY_AUTH_CLS), UPD_AUTH_CLS = MIN(UPD_AUTH_CLS) WHERE GENERAL_MASTER_TYPE_NM = '需要修改的数据' GROUP BY GENERAL_MASTER_TYPE 其中,WHERE子句可以根据需要进行修改,以筛选出要修改的数据,例如可以按照GENERAL_MASTER_TYPE_NM字段来筛选。GROUP BY子句可以根据需要进行修改,以便将重复的数据合并为一个记录。如果要保留其他字段的值,可以在SET子句中添加其他字段的值。
相关问题

docker-compose mysql配置修改 sql_mode

好的,我会为您解答关于 docker-compose mysql 配置修改 sql_mode 的问题。您可以按照以下步骤操作: 1.在您的 docker-compose.yml 文件中,找到 mysql 服务对应的配置部分。 2.在该配置部分中,找到 environment 配置项,并添加以下内容: MYSQL_ALLOW_EMPTY_PASSWORD=true MYSQL_DATABASE=db_name MYSQL_USER=user MYSQL_PASSWORD=password MYSQL_ROOT_PASSWORD=root 其中,MYSQL_ALLOW_EMPTY_PASSWORD 表示允许使用空密码,MYSQL_DATABASE 表示要创建的数据库名称,MYSQL_USER 表示要创建的数据库用户,MYSQL_PASSWORD 表示该用户的密码,MYSQL_ROOT_PASSWORD 表示 MySQL 根用户的密码。您可以根据实际情况修改这些值。 3.接着,在该配置部分中,找到 volumes 配置项,添加以下内容: - ./mysql-data:/var/lib/mysql 其中,./mysql-data 表示映射宿主机上的目录到容器中的 /var/lib/mysql 目录,用于保存 MySQL 数据。 4.最后,在该配置部分中,找到 command 配置项,添加以下内容: command: --sql-mode="" 该命令表示将 MySQL 的 sql_mode 参数设置为空,以使其兼容与其他数据库系统的应用程序。 以上就是关于 docker-compose mysql 配置修改 sql_mode 的全部内容,希望对您有所帮助。

sql-mode去掉了only_full_group_by不生效依然报错

您好!对于SQL模式中的 `ONLY_FULL_GROUP_BY`,它是在MySQL 5.7版本引入的一种严格模式,用于确保`GROUP BY`语句中的列都包含在聚合函数中。如果您在MySQL 5.7版本以后的版本中遇到了该报错,可能有以下几种原因: 1. SQL模式未正确修改:请确保您已经修改了MySQL的全局配置文件(例如my.cnf或my.ini),并在[mysqld]部分添加了`sql-mode`参数。 2. 修改不生效:有些MySQL版本可能在其他配置文件中或启动脚本中设置了`sql-mode`参数,您需要检查这些文件并确保修改生效。 3. 动态设置被覆盖:如果您在MySQL命令行或客户端中使用`SET`语句修改了`sql_mode`参数,但没有永久保存到配置文件中,则重启MySQL服务器后会恢复默认设置。 4. 其他因素:有时候报错可能与其他SQL查询或表结构有关。请确认您的GROUP BY语句是否符合语法规则,并且没有其他引起报错的因素。 为了更详细地排查问题,我建议您提供更多的信息,例如具体的报错信息、MySQL版本、相关的SQL查询语句等。这样我可以更好地帮助您解决这个问题。

相关推荐

错误 "this is incompatible with sql_mode=only_full_group_by" 表示在使用group by时出现了不兼容sql_mode=only_full_group_by模式的情况。 这个错误通常是由于SELECT语句中的表达式不在GROUP BY子句中,并且包含了未在GROUP BY子句中的非聚合列所引起的。 要解决这个错误,你可以按照以下步骤操作: 1. 确保你的SQL查询语句遵循当前的only_full_group_by模式。这意味着所有未在GROUP BY子句中的列应该使用聚合函数进行包裹,或者不在SELECT语句中选择未在GROUP BY子句中的列。 2. 对于Linux系统,在my.conf配置文件的[mysqld]标签末尾添加sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION。这样可以关闭only_full_group_by模式,以兼容不符合该模式的查询语句。 通过以上操作,你应该能够解决错误 "this is incompatible with sql_mode=only_full_group_by"。123 #### 引用[.reference_title] - *1* *3* [MySQL sql_mode=only_full_group_by错误、my.cnf修改后不起作用问题解决方案,全再现](https://blog.csdn.net/huaishitou/article/details/119759337)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [MySQL错误-this is incompatible with sql_mode=only_full_group_by完美解决方案](https://blog.csdn.net/u012660464/article/details/113977173)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

最新推荐

MyBatis-Plus 动态表名SQL解析器的实现

主要介绍了MyBatis-Plus 动态表名SQL解析器的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

MySQL复制出错 Last_SQL_Errno:1146的解决方法

主要介绍了MySQL复制出错 Last_SQL_Errno:1146的解决方法,需要的朋友可以参考下

SQLServer中Partition By及row_number 函数使用详解

partition by关键字是分析性函数的一部分,partition by用于给结果集分组,如果没有指定那么它把整个结果集作为一个分组,本文给大家介绍SQLServer中Partition By及row_number 函数使用详解,需要的朋友参考下

SQL Server阻止了对组件xp_cmdshell过程的解决方案.docx

SQL Server阻止了对组件xp_cmdshell过程的解决方案。 错误描述:SQL Server阻止了对组件‘xp_cmdshell’的过程‘sys.xp_cmdshell’的访问。因为此组件已作为此服务嚣安全配置的一部分而被关闭。系统管理员可以通过...

SQL Server中T-SQL 数据类型转换详解

常用的转换函数是 cast 和 convert,用于把表达式得出的值的类型转换成另一个数据类型,如果转换失败,该函数抛出错误,导致整个事务回滚。在SQL Server 2012版本中,新增两个容错的转换函数:try_cast 和 try_...

基于单片机温度控制系统设计--大学毕业论文.doc

基于单片机温度控制系统设计--大学毕业论文.doc

ROSE: 亚马逊产品搜索的强大缓存

89→ROSE:用于亚马逊产品搜索的强大缓存Chen Luo,Vihan Lakshman,Anshumali Shrivastava,Tianyu Cao,Sreyashi Nag,Rahul Goutam,Hanqing Lu,Yiwei Song,Bing Yin亚马逊搜索美国加利福尼亚州帕洛阿尔托摘要像Amazon Search这样的产品搜索引擎通常使用缓存来改善客户用户体验;缓存可以改善系统的延迟和搜索质量。但是,随着搜索流量的增加,高速缓存不断增长的大小可能会降低整体系统性能。此外,在现实世界的产品搜索查询中广泛存在的拼写错误、拼写错误和冗余会导致不必要的缓存未命中,从而降低缓存 在本文中,我们介绍了ROSE,一个RO布S t缓存E,一个系统,是宽容的拼写错误和错别字,同时保留传统的缓存查找成本。ROSE的核心组件是一个随机的客户查询ROSE查询重写大多数交通很少流量30X倍玫瑰深度学习模型客户查询ROSE缩短响应时间散列模式,使ROSE能够索引和检

如何使用Promise.all()方法?

Promise.all()方法可以将多个Promise实例包装成一个新的Promise实例,当所有的Promise实例都成功时,返回的是一个结果数组,当其中一个Promise实例失败时,返回的是该Promise实例的错误信息。使用Promise.all()方法可以方便地处理多个异步操作的结果。 以下是使用Promise.all()方法的示例代码: ```javascript const promise1 = Promise.resolve(1); const promise2 = Promise.resolve(2); const promise3 = Promise.resolve(3)

android studio设置文档

android studio默认设置文档

社交网络中的信息完整性保护

141社交网络中的信息完整性保护摘要路易斯·加西亚-普埃约Facebook美国门洛帕克lgp@fb.com贝尔纳多·桑塔纳·施瓦茨Facebook美国门洛帕克bsantana@fb.com萨曼莎·格思里Facebook美国门洛帕克samguthrie@fb.com徐宝轩Facebook美国门洛帕克baoxuanxu@fb.com信息渠道。这些网站促进了分发,Facebook和Twitter等社交媒体平台在过去十年中受益于大规模采用,反过来又助长了传播有害内容的可能性,包括虚假和误导性信息。这些内容中的一些通过用户操作(例如共享)获得大规模分发,以至于内容移除或分发减少并不总是阻止其病毒式传播。同时,社交媒体平台实施解决方案以保持其完整性的努力通常是不透明的,导致用户不知道网站上发生的任何完整性干预。在本文中,我们提出了在Facebook News Feed中的内容共享操作中添加现在可见的摩擦机制的基本原理,其设计和实现挑战,以�