- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我创建了一个准备好的语句来从 MySQL 数据库中获取一些结果,然后我想在同一页面上的多个框中显示这些结果。
我多次使用相同的准备语句来获取不同的结果集,然后使用一个片段将它们变成一个菜单。
出了什么问题:在某些选择框中,文本被随机截断。假设数据库中的文本显示“This is a long text”,我得到“This is a long t”。在另一个字段上,它只给出首字母“E”,而不是包含的 3 个单词。
如果我删除 $stmtPedibles->store_result();
, 文本将不再被截断。然而,如果我这样做,我就不能使用 <?php if ($executed_stmt->num_rows > 0) : ?>
在选择框片段中,这对我很重要,因为我需要知道选择框是否为空。有解决方法吗?
代码:
1。主文档
<?php
$root = "";
$thisfile = "index.php";
require_once($root."includes/setup/user.php");
require($root."includes/snippets/prepared_queries.php");
require_once($root."includes/layout/doc_head.php");
$thisGerencia = "Produccion"; //Ventas, Almacen, Produccion
//Variables que se repiten en toda la página
$ped_gerencia = $thisGerencia;
$ped_usuario = $thisUsr;
?>
<body>
<h2>Elementos disponibles</h2>
<h3><?php echo strtoupper($thisGerencia);?> - Diálogos disponibles: </h3>
<p>Prep statement + build function</p>
<?php //PEDIDO 1
$ped_tipo = "Q";
$stmtPedibles->execute(); //4. Execute
$stmtPedibles->bind_result($selText, $selValue, $nada1, $nada2); //5. Bind results (for selects, always include $selValue and $selCodigo)
//Vars para select:
$executed_stmt = $stmtPedibles; //Esto hace que el siguiente snippet funcione.
$select_name = "dialogos_pedibles";
$select_required = TRUE;
$select_selected = FALSE;
$default_option_text = "Hacer una pregunta...";
include($root."includes/snippets/select_box.php");
?>
<?php //PEDIDO 2
$ped_tipo = "I";
$stmtPedibles->execute(); //4. Execute
$stmtPedibles->bind_result($selText, $selValue, $nada1, $nada2); //5. Bind results (for selects, always include $selValue and $selCodigo)
//Vars para select:
$executed_stmt = $stmtPedibles; //Esto hace que el siguiente snippet funcione.
$select_name = "dialogos_pedibles";
//$select_required = TRUE;
$select_selected = FALSE;
$default_option_text = "Hacer una pregunta...";
include($root."includes/snippets/select_box.php");
?>
<h3><?php echo strtoupper($thisGerencia);?> - Informes disponibles: </h3>
<?php //PEDIDO 3
$ped_tipo = "P";
$stmtPedibles->execute(); //4. Execute
$stmtPedibles->bind_result($selText, $selValue, $nada1, $nada2); //5. Bind results (for selects, always include $selValue and $selCodigo)
//Vars para select:
$executed_stmt = $stmtPedibles; //Esto hace que el siguiente snippet funcione.
$select_name = "informes_pedibles";
//$select_required = TRUE;
$select_selected = FALSE;
$default_option_text = "Solicitar un informe...";
include($root."includes/snippets/select_box.php");
$executed_stmt->close();
$stmtPedibles->close();
?>
<?php include($root."includes/setup/user_footer.php");?>
</body>
</html>
2。准备好的声明
<?php
$prep_elementos_pedibles = "SELECT EvePar_Pregunta, EvePar_EventoCodigo, EvePar_EventoNombre, EvePar_CodigoInforme
FROM Estado_Jugador JOIN Eventos_Parametros ON Estado_Codigo = EvePar_EventoCodigo
WHERE EvePar_EventoLugar = ? AND Estado_Habilitado = 1 AND Evento_EventoTipo = ? AND Estado_usr_name = ?";
$stmtPedibles = $connection->prepare($prep_elementos_pedibles); //1. Prepare
if (!$stmtPedibles) { //2. Check for errors
trigger_error('Wrong SQL: ' . $prep_elementos_pedibles . ' Error: ' . $conn->error, E_USER_ERROR);
}
$stmtPedibles->bind_param("sss", $ped_gerencia, $ped_tipo, $ped_usuario); //3. Bind
?>
3。选择框代码段
<?php
//THIS WAY; TEXT GETS CUT OFF
$executed_stmt->store_result();
if ($executed_stmt->num_rows > 0) : ?>
<select name="<?php echo $select_name;?>" class="<?php if ($select_required) {echo "required";} ?>">
<?php if ($default_option_text !="") : ?>
<option value=""><?php echo $default_option_text;?></option>
<?php endif;?>
<?php while ($executed_stmt->fetch()) :
if ($select_selected == $selValue) {
$selected = " selected='selected' ";
} else {
$selected = "";
}
?>
<option value="<?php echo $selValue;?>" <?php echo $selected;?> ><?php echo $selText;?></option>
<?php endwhile;?>
</select>
<?php endif;
$executed_stmt->free_result();
?>
编辑 1:我刚刚清理了代码,因为 bad_boy 提到我不应该创建一些变量。我搬了store_result
和 free_result
到选择框片段,希望它们会有所作为,但事实并非如此。
我还附上了表结构的屏幕截图:
我应该放弃使用 num_rows 吗?那将意味着我真的放弃了准备好的语句...如果我不使用准备好的语句,MySQLi 是否比 MySQL 语句更安全?真是令人沮丧... :-(
最佳答案
我真的不知道它为什么要进行随机文本切断,但如果您可以稍微重新组织选择框的构建方式,那么您似乎可以消除检查 num_rows 的需要。我想如果你制作一个包含所有 <option>
的字符串s,然后做你的while ... fetch...
创建选项列表的东西,然后你可以构建其余的<select>
如果它不是空的,则在它周围,或者如果它是,则不要。像这样:
<?php
$options = "";
while ($executed_stmt->fetch()) {
if ($select_selected == $selValue) {
$selected = " selected='selected' ";
} else {
$selected = "";
}
$options .= "<option value=\"$selValue\"$selected>$selText</option>";
}
?>
<?php if ($options) : ?>
<select name="<?php echo $select_name;?>" class="<?php if ($select_required) {echo "required";} ?>">
<?php if ($default_option_text !="") : ?>
<option value=""><?php echo $default_option_text;?></option>
<?php endif;?>
<?php echo $options;?>
</select>
<?php endif; ?>
关于PHP 从查询结果中截断文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25047563/
我有一个 1850-2005 年月地表气温的 netCDF 文件。如何在 unix 中截断文件,以便新文件的时间维度从 1855 年到 2005 年?反之亦然,截断文件,使其改为 1850-2000?
我收到此错误 Bulk load data conversion error (truncation) for row 1, column 12 (is_download) 这是 csv...它只有一
我有一个列表,它是电子邮件正文,每行末尾都有一个日期和时间戳。邮票的格式是一致的,所以可以从右边计算表达式。以下是示例数据: Dear Volunteer2018-05-21 19:59:15 You
我正在使用内置 truncatewords_html Django 的过滤器,它在最后添加了“...”,相反,我想用“查看更多”链接替换它。 我怎样才能做到这一点? 最佳答案 最好编写自己的过滤器。您
我正在使用 SQL 加载器将我的数据加载到数据库中。 在插入数据之前,我需要删除表中的现有数据: options(skip=1,load=250000,errors=0,ROWS=30000,BIND
我正在尝试掌握消息队列的窍门。由于某种原因,当显示我在控制台中输入的消息时,字符串有时会被截断或更改。有谁知道为什么会发生这种情况? void *readFromQueue() { int r
我正在使用mediawiki API(例如http://en.wikipedia.org/w/api.php),我希望能够“截断”mysql表以便重置本地安装,同时保留一些表(用户,?...) 。SQ
想要截断一个存在的表: IF EXISTS(SELECT 1 FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = 'mytable') TRUNCATE
我正在实现一个使用 Python Numpy 包的程序。我正在尝试修改数组的元素,以便我只需采用 elem[i][j] 并将其设置为 elem[i][j]/10。但是,我不断收到某种截断,其中元素在操
我有一个 64 位 long int,其中包含一些位域。我需要将存储在第二个和第三个字节中的 16 位带符号整数添加到一个 32 位值中。我正在使用这样的东西: u32 Function( s32 v
我有这样的文字:“我的文字是 blabla blabla, lala lala”。 我希望在我的 UILabel 中有这样的文本:“My text is ...lala”。 如何配置我的 UILabe
Umbraco Truncate 似乎不适合我,当我使用正确的代码(根据互联网)时,它会不断出错。我不知道它有什么问题。 错误代码: Compiler Error Message: CS1502: T
早些时候,我是使用 JS 动态地完成它的。但是我们遇到了一些性能问题,因为我们必须提供一个替代选项。 我现在使用文本溢出样式截断选项卡名称上的长文本。 但我有一个小问题,如果有人能解决的话 目前这是我
使用Rspec时截断、事务和删除数据库策略有什么区别?我找不到任何资源来解释这一点。我阅读了 Database Cleaner 自述文件,但它没有解释它们各自的作用。 为什么我们必须对 capybar
当然, 尚有诸位前辈也曾把以上三种方案结合一二, 以达到更广泛的适应度. 不过, 这厢先前在网路上搜索许久, 却未曾寻到三种方案合为一体的尝试, 于是只好自己动手写一下了:) 没有dem
有没有办法截断HSQLDB中的所有表? 如果这不可能,是否有任何方法可以级联删除具有外键引用的表? 最佳答案 可以截断模式中的所有表: 截断模式并提交 此命令有一些选项在指南中有描述: http://
我有一个要截断的时间戳。我正在使用 trunc oracle中的函数。这似乎做了我想要的但是从文档中它应该只接受日期而不是时间戳 select TRUNC(TO_DATE('22-AUG-13'),
我读到一旦你耗尽了一个节点,你就可以删除文件然后重新启动。它工作正常, 但我只是通过排空所有节点,关闭整个集群,删除文件并重新启动来尝试它。 如果我一次只重启一个节点会怎样?据我了解有风险 重新启动的
我想截断 d3 中超过预定义限制的文本。 我不知道该怎么做。 这是我现在所拥有的: node.append("text") .attr("dx", 20) .attr("dy", ".20
嗨 Guyz 我有一个固定宽度的 WPF TextBlock 说 100 ,如果字符串不适合宽度,则最后一个字符总是被截断,因为所有字符的大小都不相同。我不想剪切字符而是我想从那里跳过文本并只显示没有
我是一名优秀的程序员,十分优秀!