在 SQL 查询中使用文本字段值而不提交它

Posted

技术标签:

【中文标题】在 SQL 查询中使用文本字段值而不提交它【英文标题】:Using text field value in SQL query without it being submitted 【发布时间】:2012-12-12 17:14:41 【问题描述】:

我正在使用 Oracle Application Express (Apex),基本上我的情况是:我有 2 个项目,一个是文本字段,另一个是隐藏项目,其值是通过使用 DB 链接查询表来检索的。

应该发生的情况是用户在文本字段中输入一个数字,然后在查询隐藏项时使用该数字来查找 ID 与用户输入的数字匹配的行。然后将隐藏项的值设置为该行的其中一列的内容。

唯一的问题是,这一切都在一个页面上,必须在不提交页面的情况下完成,所以当用户在文本字段中输入数字时,我如何将该数字存储为该项目的值,以便它可以在查询中用于计算隐藏项的值?

任何帮助将不胜感激。

【问题讨论】:

什么版本的 Apex?动态操作可以在 Apex 4.0 及更高版本中执行此操作。 @JeffreyKemp Apex 4.2,我会看看动态动作,如果你知道我如何使用动态动作来做到这一点,请告诉我,谢谢 您创建了一个动态操作,该操作在文本字段项上的 Change 事件上触发。 True 操作是一个 PL/SQL 块,它可以检索隐藏项的值。 【参考方案1】:

更新:

<!DOCTYPE html>
<html>
    <head>
        <script>
            function ajax(user_number) 
                var xmlhttp;
                // get the ID field for easy access... 
                var index =  document.getElementById("index");
                if (window.XMLHttpRequest) // code for IE7+, Firefox, Chrome, Opera, Safari
                    xmlhttp = new XMLHttpRequest();
                 else // code for IE6, IE5
                    xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
                
                xmlhttp.onreadystatechange = function() 
                    if (xmlhttp.readyState == 4 && xmlhttp.status == 200) 
                        // here you get back a response... xmlhttp.responseText
                        // set the hidden field with new data.
                        index.value = xmlhttp.responseText;
                    
                
                // here you make a request to your script to check your database...
                xmlhttp.open("GET", "app/search/?number=" + user_number + '&index=' + index.value, true);
                xmlhttp.send();
            

            function check(user_number) 
                // make some validation here...
                if (user_number.length > 3) 
                    ajax(user_number);
                 else 
                    return;
                
            
        </script>
    </head>
    <body>

        <p>please enter your secret number</p>
        <!-- the hidden field holding the ID -->
        <input type="hidden" id="index" name="index" value="334" />
        <!-- the search text box where user type his own NUMBER onkeyup it make a request -->
        <input type="text" id="user-number" name="user-number" onkeyup="check(this.value);"/>

    </body>
</html>

【讨论】:

以上是关于在 SQL 查询中使用文本字段值而不提交它的主要内容,如果未能解决你的问题,请参考以下文章

在 MongoDB 中搜索任何字段的值而不显式命名它

LINQ 查询在 C# 中使用实体框架获取单列和单行值而不使用 Where

提交文本框的值而不重新加载页面

在修改/允许修改引用值而不触及字段本身的方法上使用或不使用 const

在 Sencha Touch 中设置 numberfield 的值而不触发“change”事件

使用 sql 查询向字段添加文本