Php 如何在MS SQL Server中连接两个列值
我正在从PHP查询MS SQL Server数据库。该查询可以工作,但当我尝试在first_name和last_name字段之间插入空格时,出现了一个错误 当我这样编写查询时,它会工作:Php 如何在MS SQL Server中连接两个列值,php,sql-server,Php,Sql Server,我正在从PHP查询MS SQL Server数据库。该查询可以工作,但当我尝试在first_name和last_name字段之间插入空格时,出现了一个错误 当我这样编写查询时,它会工作: $query = 'SELECT meetings.name as Subject, meetings.date_entered, meetings.date_modified, SELECT (users
$query = 'SELECT meetings.name as Subject,
meetings.date_entered,
meetings.date_modified,
SELECT (users.first_name + users.last_name) as Fullname FROM dbo.users WHERE users.id = meetings.assigned_user_id';
if($custom_join) {
$query .= $custom_join['select'];
}
$query .= ' FROM meetings ';
$query = 'SELECT meetings.name as Subject,
meetings.date_entered,
meetings.date_modified,
SELECT (users.first_name + ' ' + users.last_name) as Fullname FROM dbo.users WHERE users.id = meetings.assigned_user_id';
if($custom_join) {
$query .= $custom_join['select'];
}
$query .= ' FROM meetings ';
然而,当我写的时候,我试图在名字和姓氏之间留出一个空格,但失败了,就像这样:
$query = 'SELECT meetings.name as Subject,
meetings.date_entered,
meetings.date_modified,
SELECT (users.first_name + users.last_name) as Fullname FROM dbo.users WHERE users.id = meetings.assigned_user_id';
if($custom_join) {
$query .= $custom_join['select'];
}
$query .= ' FROM meetings ';
$query = 'SELECT meetings.name as Subject,
meetings.date_entered,
meetings.date_modified,
SELECT (users.first_name + ' ' + users.last_name) as Fullname FROM dbo.users WHERE users.id = meetings.assigned_user_id';
if($custom_join) {
$query .= $custom_join['select'];
}
$query .= ' FROM meetings ';
我得到的错误是在SQL表中不是有效列或类似的列
我使用的全名也是小写:->Fullname。为什么大写字母“F”会变成小写字母“F”
我主要在MySQL上工作,但我对MS SQL还是相当陌生的……这有点奇怪。即使Concat函数在这里也不起作用。当我尝试使用它时,它告诉我它不是一个内置函数
编辑:
编辑2:
您在字符串常量中留下了一个空格 而不是使用“”
请查看此问题的SQLFIDLE:如果使用CONCAT函数会发生什么
SELECT CONCAT(users.first_name, SPACE(1) ,users.last_name) AS Result FROM dbo.users WHERE users.id = meetings.assigned_user_id
从上下文来看,您可能没有在SSMS中运行此精确查询,因此您可能缺少转义要保留的单引号所需的额外单引号:
(SELECT users.first_name + '' '' +users.last_name as Fullname)
更新:我从你的问题更新中看到我是正确的,但你也得到了一个无效的查询,没有第二个from子句,很难确切地说出你想要什么,但也许:
$query = 'SELECT meetings.name as Subject,
meetings.date_entered,
meetings.date_modified,
users.first_name + '' '' + users.last_name as Fullname
FROM dbo.users
JOIN dbo.meetings
ON users.id = meetings.assigned_user_id)
';
问题不再是连接,而是SQL查询格式错误。连接问题是由单引号字符串中的单引号引起的 以下代码应返回有效的查询:
$query = "SELECT meetings.name as Subject,
meetings.date_entered,
meetings.date_modified,
(SELECT users.first_name + ' ' + users.last_name
FROM dbo.users WHERE users.id = meetings.assigned_user_id
) as Fullname
";
//$query = 'SELECT meetings.*';
if($custom_join) {
$query .= $custom_join['select'];
}
$query .= " FROM meetings ";
这是查询的外观:
$query = "SELECT meetings.name as Subject,
meetings.date_entered,
meetings.date_modified,
(SELECT users.first_name + ' ' + users.last_name)
FROM dbo.users WHERE users.id = meetings.assigned_user_id
) as Fullname
FROM meetings";
http://stackoverflow.com/questions/5247381/sql-combine-two-columns-in-select-statement 这可能有助于uyes我看到了该链接,但我需要在名字和姓氏之间留出一个空格bro.SELECT users.first_name+''+users.last_name作为来自dbo.users WHERE users.id=meetings.assigned_user_id的全名-尝试使用此链接。你肯定用单引号而不是双引号吗?CONCAT是SQL Server 2012中的内置函数,但在早期版本中不起作用。@Prava它不起作用..谢谢。不,它也不起作用:-->选择用户。first_name+''+users.last_name作为dbo.users WHERE users.id=meetings.assigned_user的全名_id@RaphaëlAlthaus,也许他用了一个双引号,把他的问题打错了。没有提供足够的信息来解释他看到的错误,但是,有足够的信息来确定他的查询是错误的。@user3054077,请提供您看到的错误消息。它说这不是一个内置函数我使用的是较旧版本的sql 2008。您的编辑显示一个无效的查询,其中只有一个FROM子句,但引用了两个表,并且没有联接。在我更新的答案中,我已经猜到了你真正想要的是什么。如果我删除这个:-->++,它可以工作,但是第一个名字和第二个名字粘在一起,你混淆了两个单引号和一个双引号。我这里有4个单引号。。。。单引号单引号空格单引号单引号从dbo中选择users.first_name++users.last_name作为全名。userstry->$query=从dbo.users中选择users.first_name++users.last_name作为全名。这里我用双引号将整个查询连接起来,只有两个单引号。你的意思是->从dbo.users中选择users.first\u name+“”+users.last\u name作为全名,其中users.id=meetings.assigned\u user\id