- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有以下在 MySQL 中完美执行的查询,但在 MS SQL Server 上执行时却给我带来了麻烦:
SELECT failedlogins.*, siteprofiles.failedLogins AS max,
COUNT(failedlogins.id) AS total
FROM failedlogins RIGHT JOIN siteprofiles ON failedlogins > 0
WHERE computerName LIKE 'some awesome name' AND timeStamp > 1340752043
GROUP BY computerName
我收到以下错误:
Msg 8120, Level 16, State 1, Line 2
Column 'failedlogins.id' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.
Msg 8120, Level 16, State 1, Line 2
Column 'failedlogins.timeStamp' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.
Msg 8120, Level 16, State 1, Line 2
Column 'failedlogins.userName' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.
Msg 8120, Level 16, State 1, Line 2
Column 'siteprofiles.failedLogins' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.
我认为它与RIGHT JOIN
有关,但我不确定如何解决。
正如旁注,如果您不熟悉 MySQL,我将 siteprofiles
中的唯一行正确加入到 failedlogins
表中。通常,您会看到一个 =
符号,表示喜欢多个表中的两行。在 MySQL 中,如果您只选择一个行来联接表,并且不使用等号运算符将行链接在一起,它将将该行联接到返回的每一行。
有人可以帮我调试上面的语句吗?
编辑:
这是构造failedlogins
表的 SQL:
CREATE TABLE failedlogins (
"id" int NOT NULL,
"timeStamp" int NOT NULL,
"computerName" NTEXT NOT NULL,
"userName" NTEXT NOT NULL,
PRIMARY KEY ("id")
) ;
和 siteprofiles
表:
CREATE TABLE siteprofiles (
"id" int NOT NULL,
"siteName" varchar(200) NOT NULL,
"paddingTop" tinyint NOT NULL,
"paddingLeft" tinyint NOT NULL,
"paddingRight" tinyint NOT NULL,
"paddingBottom" tinyint NOT NULL,
"width" int NOT NULL,
"height" int NOT NULL,
"sideBar" text NOT NULL,
"auto" text NOT NULL,
"siteFooter" text NOT NULL,
"author" varchar(200) NOT NULL,
"language" varchar(15) NOT NULL,
"copyright" varchar(200) NOT NULL,
"description" NTEXT NOT NULL,
"meta" text NOT NULL,
"timeZone" varchar(20) NOT NULL,
"welcome" text NOT NULL,
"style" varchar(200) NOT NULL,
"iconType" text NOT NULL,
"spellCheckerAPI" varchar(50) NOT NULL,
"saptcha" text NOT NULL,
"question" NTEXT NOT NULL,
"answer" NTEXT NOT NULL,
"failedLogins" int NOT NULL,
PRIMARY KEY ("siteName")
);
INSERT INTO siteprofiles (id, siteName, paddingTop, paddingLeft, paddingRight, paddingBottom, width, height, sideBar, auto, siteFooter, author, language, copyright, description, meta, timeZone, welcome, style, iconType, spellCheckerAPI, saptcha, question, answer, failedLogins) VALUES
(1, 'The Bell News Magazine', 0, 0, 0, 0, 260, 180, 'Right', '', '<p>© 2011 The Bell News Magazine</p>', 'The Bell News Magazine', 'en-US', '© 2011 The Bell News Magazine', 'The collaborative, innovative Bell News Magazine', 'The Bell News Magazine, The PAVCS Bell News Magazine, The Pennsylvania Virtual Charter School Bell News Magazine, Pennsylvania Virtual Charter School Bell News Magazine, Bell News Magazine, Bell News, Bell Magazine, The Bell Magazine, The Bell News', 'America/New_York', 'Ads', 'onlineUniversity.css', 'gif', 'jmyppg6c5k5ajtqcra7u4eql4l864mps48auuqliy3cccqrb6b', 'auto', '', '', 5);
感谢您的宝贵时间。
最佳答案
自从提供第一个答案后,您似乎已经编辑了问题。错误的调子
Column 'failedlogins.id' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.
... 是因为尽管 MySQL(在其默认配置中)对 GROUP BY
的内容非常宽松,但其他 RDBMS 却不是。为了从 failedlogins.*
中提取所有其他列,您需要针对仅对其相关组列进行计数的子查询JOIN
。
SELECT
failedlogins.*,
siteprofiles.failedlogins AS max,
logincount
FROM
failedlogins RIGHT JOIN siteprofiles ON failedlogins > 0
/* Join matches remaining columns to the counts of computerName */
INNER JOIN (
/* Subquery gets computerName and count to join against */
SELECT computerName, COUNT(*) logincount FROM failedlogins GROUP BY computerName
) logincounter ON failedlogins.computerName LIKE logincounter.computerName
WHERE failedlogins.computerName LIKE 'some awesome name' AND timeStamp > 1340752043
关于mysql - 从 MySQL 到 MS SQL,所有列都无效?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11236628/
我有一个接受以下参数的函数: int setvalue(void (*)(void *)); 为了满足参数:void (*)(void *),我创建了这样一个函数: static void *
我有以下代码: typedef void VOID; int f(void); int g(VOID); 在 C 中编译得很好(在 Fedora 10 上使用 gcc 4.3.2)。与 C++ 编译的
这个问题已经有答案了: Is f(void) deprecated in modern C and C++? [duplicate] (6 个回答) 已关闭 7 年前。 B.A.T.M.A.N./A.
我在 ASP.NET Core 3.1 项目上有以下 Identity Server 4 配置: services .AddIdentityServer(y => { y.Events.R
我们有一个 O365 租户,一切都是开箱即用的。租户放置在德国云中,而不是全局 (office.de) 中。我们还开发了一个 Office 插件,使用 OAuth 2.0 授权访问共享点。首先,我们向
我有一个如下所示的路由 routes.MapRoute( name: "Default", url: "{controller}/{action}/{i
我正在尝试使用 OAuth2.0 访问 google 文档。我已经从 Google API 控制台获取了客户端 ID 和 key 。但是当我运行这段代码时,我收到了异常。如果我遗漏了什么,有人可以建议
此代码有效: let mut b: Vec = Vec::with_capacity(a.len()); for val in a.iter() { b.push(val); } 此代码不起作
使用 client_credintials 授权类型请求 EWS oauth2 v2.0 的访问 token 时出现错误。 https://login.microsoftonline.com/tena
我通过 Java 应用程序使用 Google 电子表格时遇到了问题。我创建了应用程序,该应用程序运行了 1 年多,没有任何问题,我什至在 Create Spreadsheet using Google
如何创建 匹配所有无效 Base64 字符的正则表达式?我在堆栈上找到了 [^a-zA-Z0-9+/=\n\r].*$ 但是当我尝试时我得到了带有 - 符号的结果字符串.我根本不知道正则表达式,任何人
我从 Gitlab CI/CD Pipelines 获得错误信息:yaml invalid。问题是由 .gitlab-ci.yml 脚本的第五行引起的: - 'ssh deployer@gita
我有 3 个数据源,设置如下: @Configuration @Component public class DataSourceConfig { @Bean("foo") @Conf
你好,我想用bulkCreate ex 插入数据: [ { "typeId": 5, "devEui": "0094E796CBFCFEF9", "application_name": "Pressu
UIApplicationExitsOnSuspend 不会强制我的应用程序退出。我已经清理过目标、删除了应用程序、重建并重新安装了很多次。 我确实需要退出我的应用程序。 最佳答案 您是否链接了 SD
在 iPhone 配置门户上,显示我的 iPhone 团队配置配置文件无效。有一个“由 Xcode 管理”文本。 “续订”按钮被禁用。 我该如何解决这个问题?谢谢 最佳答案 使用 Xcode 3.2.
好的,所以今天我用我们的“实时”数据库中的新信息更新了我的数据库……从那时起,我的一个表格就出现了问题。如果您需要任何代码,请告诉我,我将对其进行编辑并发布所需的代码... 我有一个报告表格,其中有一
我有一个结构体,其中有一个元素表示为 void (*func)(); 我知道 void 指针通常用于函数指针,但我似乎无法定义该函数。我不断收到取消引用指向不完整类型的指针。我用谷歌搜索了一下但没有结
我正在尝试使用 Coldfusion 9 从 ning 网络获取凭证,所以首先这是测试 api 的 curl 语法: curl -k https://external.ningapis.com/xn/
这个问题已经有答案了: Does C have references? (2 个回答) 已关闭 4 年前。 我正在学习 C 语言引用,这是我的代码: #include int main(void)
我是一名优秀的程序员,十分优秀!