- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在尝试将价格范围与这样的 SELECT 下拉列表一起使用:
<select name="valor">
<option value="" selected="selected">Faixa de Valor</option>
<option value="100000.00 , 200000.00">De R$ 100 a 200 mil</option>
<option value="200000.00 , 500000.00">De R$ 200 a 500 mil</option>
<option value="500000.00 , 1000000.00">De R$ 500 a 1 milhão</option>
<option value="1000000.00 , 5000000.00">De R$ 1 a 5 milhões</option>
<option value="5000000.00">Acima de 5 Milhões</option>
</select>
我的 PHP 语句是:
$valor_query = $_POST['valor'];
$values = explode(' , ', $valor_query);
$valor1 = $values[0];
$valor2 = $values[1];
$statements .= " AND ( (property_selling.valor >= '$valor1' AND property_selling.valor >= '$valor2') OR (property_renting.valor >= '$valor1' AND property_renting.valor >= '$valor2') ) ";
但它不起作用,我有 2 个不同的表,一个用于销售,另一个用于出租,我将此语句添加为这样的变量:
$filtraSegmento = "SELECT * FROM properties, property_complements,
property_details, property_selling, property_renting
WHERE property_complements.imovel_id = properties.property_id
AND property_details.imovel_id = properties.property_id
AND (property_renting.imovel_id = properties.property_id
OR property_selling.imovel_id = properties.property_id)
AND properties.property_status = 'Aprovado' $statements
GROUP BY properties.property_id";
有什么提示吗?
编辑
按照@Strawberry 和@Sean 的建议,我使用 LEFT JOIN 重新创建了查询,现在它看起来像:
$filtraSegmento = "
SELECT p.*, c.*, d.*, s.*, r.*
FROM properties p
LEFT
JOIN property_complements c
ON c.imovel_id = p.property_id
LEFT
JOIN property_details d
ON d.imovel_id = p.property_id
LEFT
JOIN property_selling s
ON s.imovel_id = p.property_id
LEFT
JOIN property_renting r
ON r.imovel_id = p.property_id
WHERE $statements
";
它现在运行良好,但我的问题是,我将其用作过滤器,而用户继续过滤时,变量 $statements
不断添加新条件。所以我有这样的数组格式:
$statements = '';
if (isset($_POST['segmento']) && !empty($_POST['segmento'])) {
$segmento_query = $_POST['segmento'];
$statements .= " detail.segmento = '$segmento_query' "; //condition for each property
}
if (isset($_POST['cidade']) && !empty($_POST['cidade'])) {
$cidade_query = $_POST['cidade'];
$statements .= " detail.cidade = '$cidade_query '";
}
if (isset($_POST['tipo_imovel']) && !empty($_POST['tipo_imovel'])) {
$tipo_query = $_POST['tipo_imovel'];
$statements .= " detail.tipo_imovel = '$tipo_query '";
}
if (isset($_POST['local']) && !empty($_POST['local'])) {
$local_query = $_POST['local'];
$statements .= " property.property_category = '$local_query '";
}
if (isset($_POST['valor']) && !empty($_POST['valor'])) {
$valor_query = $_POST['valor'];
$values = explode(',', $valor_query);
$valor1 = $values[0];
$valor2 = $values[1];
$statements .= " selling.valor BETWEEN '$valor1' AND '$valor2' OR renting.valor BETWEEN '$valor1' AND '$valor2' ";
}
如何将其作为新条件添加到查询中?
最佳答案
您可以像嵌套条件运算符一样尝试而不是分解提交的值。使用像 1,2,3,.. 这样的值作为选项,在你的 php 中可以这样做。
$r = $_POST["valor"]
".(
empty($r) ? "" : ( ($r == "0") ? "" :
( ($r == "1") ? "and rent <= 5000" :
( ($r == "2") ? "and rent between 5000 and 10000" : "and rent > 10000" )
)
)
)."
关于PHP MySQL 价格范围不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32132051/
我需要一些帮助。 我希望“总计”由“数量*价格=总计”计算(到目前为止没问题)。问题是我还需要通过“总/价格=数量”来计算“数量”,即如果一个字段发生更改,另一个字段也会自动更改。 我做了一个非常简单
我试图将每件商品的数量和价格相乘来计算总数,但我的警报中出现错误。 $.each(data.items, function(index, d){ var calcultest = d.pric
我想获得格式化的价格但没有货币符号,我只想使用 magento 的标准功能! $product->getFinalPrice(); => 19.9900 Mage::helper('core')->f
我正在尝试获取特定月份和年份中所有父类别的总价格。父类别是 parent_id == 0 的任何类别。我的查询如下所示: SELECT ROUND(SUM(od.total_price)) a
请帮我摆脱我的头痛..提前我为我的糟糕语言道歉,无论是英语还是mysql。希望有人能理解这个问题..:) 我有一个数据库,任何人都可以记录各个商店中各种产品的价格。以下查询是一个半理论示例,可能根本不
下面是我需要在数据库中设计的示例: 会有一个价格选项,如果有的话,会有一个特价选项,然后我想知道如果我希望其中一个选项是“免费”的,我该怎么做。 另请参阅根据所在国家/地区会有不同的货币。这是我的想法
商品价格格式 999,99 999 - 1 ..4 digits , - comma sign marks decimal point 99 - 2 digits after price Postg
我有这个表 stk +---------+--------------+ | Field | Type | +---------+--------------+ | id
是否有一个简单的格式化程序可以将我的字符串格式化为价格? 所以我的字符串是:300000 我想用空格来“300 000” or 1000000 "1 000 000" 张国荣 最佳答案 这样做: St
我想知道是否可以使用不依赖于 Excel 应用程序本地化(欧盟/美国)的 Excel 公式来自定义数字格式? 例如,我的值为 1291660。 然后使用公式=TEXT(A1;"# ##0,00") .
这是我的代码,对于价格 slider : $("#price-slider").ionRangeSlider({ min: 130, max: 575, onChange :
用户可以使用价格创建一个新实体。价格可以使用不同的货币(EUR,USD ...),因此我们可以乘以(price * convert_rate)得到实际价格。 我想做的是根据价格过滤记录,具体取决于前端
我正在尝试隐藏小数位在类型输入字段上,例如 数字从0.00开始 因此,输入字段中的第一个位置将为 0.00 我输入的1比它应该变成0.01 我输入的2比它应该变成0.12 比 0 所以它应该变成 1.
$res=mysql_query($qry); while($row= mysql_fetch_array($res)) { echo "".$row['Food_Name']." ".$row['P
我们正在为我们的新项目寻找信用卡网关。那里一片困惑,所有人都想把你切成碎片。每次我与他们交谈时,他们都有不同的费率,每次更新报价时,他们都会更改一些价格。 我们正在使用 .net、C#、asp.net
我已经创建了一个 jQuery 价格 slider ,但我不确定如何让过滤区域以实际价格范围开始?目前它有“$[object Object] - $[object Object]”,而我希望它有“$2
我已经创建了 jquery 价格 slider ,但我不确定如何过滤我的结果,以便在滑动时您只能看到具有该值范围内的产品。 HTML: Price range:
我有一个页面,其中有一个表格,我们可以在其中选择一个产品,输入它的数量和价格,然后应在最后一列中计算金额,并应添加新行以输入更多产品,直到我们完成为止。
我创建了电子商务网站,即将提供午餐和晚餐服务。我在这里提出问题/问题是因为我知道这里有很多可以帮助我的传奇人物。我在网站上添加了套餐/计划部分。 1. Weekly 2. Monthly 以下是订
我的网站需要一个简单的 jQuery 价格 slider 。从 0 英镑到 1000 英镑不等。 假设浏览器将 slider 设置为 100 英镑(例如),然后我需要一个立即购买按钮,该按钮将 sli
我是一名优秀的程序员,十分优秀!