- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
您好,我有两个表:产品和库存。他们有 manyToOne 关系,看起来是这样的:
库存:
+------------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+------------+--------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| stock_name | varchar(255) | NO | | NULL | |
| address | varchar(255) | NO | | NULL | |
+------------+--------------+------+-----+---------+----------------+
产品:
+----------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+----------+--------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| stock_id | int(11) | YES | MUL | NULL | |
| name | varchar(255) | NO | | NULL | |
| delivery | varchar(255) | NO | | NULL | |
+----------+--------------+------+-----+---------+----------------+
实体
class Products
{
/**
* @ORM\Id
* @ORM\GeneratedValue
* @ORM\Column(type="integer")
*/
private $id;
/**
* @ORM\Column(type="string")
*/
private $name;
/**
* @ORM\Column(type="string")
*/
private $delivery;
/**
* @ORM\ManyToOne(targetEntity="Stock", inversedBy="products")
* @ORM\JoinColumn(nullable=true)
*/
private $stock;
/**
* @return mixed
*/
public function getName()
{
return $this->name;
}
/**
* @param mixed $name
*/
public function setName($name)
{
$this->name = $name;
}
/**
* @return mixed
*/
public function getDelivery()
{
return $this->delivery;
}
/**
* @param mixed $delivery
*/
public function setDelivery($delivery)
{
$this->delivery = $delivery;
}
/**
* @return mixed
*/
public function getStock()
{
return $this->stock;
}
/**
* @param mixed $stock
*/
public function setStock(Stock $stock)
{
$this->stock = $stock;
}
/**
* @return mixed
*/
public function getId()
{
return $this->id;
}
}
class Stock
{
/**
* @ORM\Id
* @ORM\GeneratedValue
* @ORM\Column(type="integer")
*/
private $id;
/**
* @ORM\Column(type="string")
*/
private $stock_name;
/**
* @ORM\Column(type="string")
*/
private $address;
/**
* @ORM\OneToMany(
* targetEntity="Products",
* mappedBy="stock",
* orphanRemoval=true
* )
*/
private $products;
/**
* @return mixed
*/
public function getStockName()
{
return $this->stock_name;
}
/**
* @param mixed $stock_name
*/
public function setStockName($stock_name)
{
$this->stock_name = $stock_name;
}
/**
* @return mixed
*/
public function getAddress()
{
return $this->address;
}
/**
* @param mixed $address
*/
public function setAddress($address)
{
$this->address = $address;
}
/**
* @return mixed
*/
public function getId()
{
return $this->id;
}
/**
* @return mixed
*/
public function getProducts()
{
return $this->products;
}
/**
* @param mixed $products
*/
public function setProducts($products)
{
$this->products = $products;
}
}
我需要 sql 来为我提供与股票 ID 1 关联的所有送货地址,并仅将表 Stock 中 ID 1 下的一个股票地址添加到此数组。该数组应如下所示:
Array (
[0] => Stock Address
[1] => delivery1
[2] => delivery2
[3] => delivery3
)
我尝试了这条语句,但它给出了多个股票地址和数组中的数组:
$qb = $this->getEntityManager()->createQuery(
"SELECT o.delivery , p.address
FROM AppBundle:Products o
JOIN o.stock p
WHERE o.stock =1
");
return $qb->getScalarResult();
以及这条语句的结果:
Array (
[0] => Array (
[delivery] => Spoon str, USA
[address] => Wall street 1, USA
)
[1] => Array (
[delivery] => Lincoln street, USA
[address] => Wall street 1, USA
)
)
最佳答案
您将无法通过一个 DQL 语句直接检索您想要的数组。原因是您实际上希望示例中提取的四行来自两个不同的列。
因此您需要以某种方式处理结果。例如,您可以将代码段更改为:
$qb = $this->getEntityManager()->createQuery(
"SELECT o.delivery , p.address
FROM AppBundle:Products o
JOIN o.stock p
WHERE o.stock = 1
");
$result = $qb->getScalarResult();
return array_merge([$result[0]['address']], array_column($result, 'delivery'));
因此您将地址作为要返回的数组的第一个元素,并仅添加所有结果的交付列并添加它们。
关于php - DQL 与 JOIN Doctrine2 和 Symfony2,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33211557/
我开始从事一个用 Symfony 2.8 编写的大型项目。将整个项目升级到 SF 3 需要数百小时,现在还不可能。我想到了一个想法,将 symfony/symfony 包解压到它替换的单个包中(com
我在提交表单后使用 FOSUserEvents,但订阅者调用了两次。 这样我的验证码第一次有效第二次无效 这是我的代码 router = $router; $this->request
我有以下路线: blog_show: path: /test/123 defaults: { _controller: TotalcanBravofillBundle:Te
我是测试新手。我想测试我的功能。我已经成功安装了 phpUnit。我在互联网上查看了许多教程。但我无法获得有关测试的正确信息。这是我的功能代码: public function loginAction
我正在尝试重现 facebook batch requests 的行为在他们的图形 api 上运行。 所以我认为最简单的解决方案是在 Controller 上向我的应用程序发出几个请求,例如: pub
在 Symfony Progress Bar documentation有一个超酷酒吧的示例图像。不幸的是,看起来文档的其余部分没有解释如何获得这样的结果。 这是图片,以防您错过: 我怎么才能得到它?
我使用Finder发送假脱机电子邮件,但是自动名称生成器将点放在文件名中,有时它们出现在文件的开头。 查找程序似乎无法获取具有该名称的文件-那些文件被隐藏了……有人经历过这种行为吗?有什么建议如何使用
我正在尝试进行 LDAP 身份验证,我目前遇到此类错误: ServiceNotFoundException: The service "security.firewall.map.context.ma
有没有办法验证和检查集合数组是否为空。我已经尝试过: /** * @Assert\NotBlank() * @Assert\Length( min = 1) */ protected $work
使用Smyfony2和Doctrin2,可以使用以下示例创建数据固定装置:http://symfony.com/doc/current/bundles/DoctrineFixturesBundle/i
我看到在大多数Symfony 2示例中,例如,不存在记录时,Symfony 2会引发异常。我认为这种方法对最终用户不友好。为什么有人更喜欢引发异常而不在Flashbag上添加一些错误消息? 最佳答案
我对项目中的以下服务有疑问: app.security.guardAuthenticatorLoginPassword: class: AppBundle\Security\LoginPa
symfony缓存和登录Docker容器存在问题。 Web服务器从www-data用户和组执行,当我使用docker上安装的php从docker容器中清除symfony缓存时,它从root执行。 因此
我想了解 symfony 中的服务 我已阅读http://symfony.com/doc/2.3/book/service_container.html#creating-configuring-se
因为我对 Symfony 和 Doctrine 还很陌生,所以我有一个可能很愚蠢的问题;-) 有人可以用简单的词语向我解释集合(尤其是实体中的ArrayCollections)吗?它是什么以及何时以及
我收到了这个表格: {{ form_start(form) }} {{ form_end(form) }} 我想检查用户是否登录,我这样做了: {% if is_g
我的网站已准备好部署,我正在尝试将其设置为在线。 一些信息: 主持人是 OVH。 它不允许 SSH,我必须使用 FTP 发送文件。也没有命令行。 我现在希望能够在子目录中设置网站:/www/test(
过去几个月以来,我一直在尝试与symfony合作。昨晚我自动删除了不需要的存储库。之后,我无法使用symfony命令创建新的symfony项目。当我在终端中运行Symfony new Security
In the environnement variable, then in system variable, I edited the path and added在环境变量中,然后在系统变量
我们有一个 Symfony 1.4 应用程序,想升级到 Symfony 4。是否有可能或者我们必须重新编程该应用程序? 我们询问了我们附近的一家软件公司,他们告诉我们必须重新编写应用程序。 最佳答案
我是一名优秀的程序员,十分优秀!