Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/ruby-on-rails/54.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 如何在MS SQL Server中连接两个列值_Php_Sql Server - Fatal编程技术网

Php 如何在MS SQL Server中连接两个列值

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

我正在从PHP查询MS SQL Server数据库。该查询可以工作,但当我尝试在first_name和last_name字段之间插入空格时,出现了一个错误

当我这样编写查询时,它会工作:

$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