zoukankan      html  css  js  c++  java
  • QueryRun的Reset()方法解释

    今天写代码的时候遇到一个问题,在一个过程中用户需要多次输入查询条件,这样同一个QueryRun对象qr需要用到多次,但在第一次prompt后,后面的qr.Next()死活都不执行查询,qr的结果也就不会更新了,翻阅QueryRun的帮助文档,想找到个方法用一下,QueryRun所有的方法中reset方法比较接近俺的想像,鼠标点了下去,鼻子差点气歪,这个函数的解释空空如也,服了.不过试了一下,结果正如自己想像的那样,代码如下:
    static void qrTest(Args _args)
    {
            QueryRun qr;
            Query q;
            CustTable cust;
            ;
            q 
    = new Query();
            q.addDataSource(tableNum(custtable));

            qr 
    = new QueryRun(q);
            
            
    //First prompt
            if(qr.prompt())
            
    {
               
    while(qr.next())
               
    {
                    cust 
    = qr.get(tableNum(custTable));
                    print cust.AccountNum;
               }

            }

            
    //Second prompt
             qr.reset();
             
    if(qr.prompt())
             
    {
                  
    while(qr.next())
                   
    {
                        cust 
    = qr.get(tableNum(custTable));
                        print cust.AccountNum;
                   }

            }


            pause;

    }

    重点也就在//second prompt后面的那句qr.reset()了.
    试着将该函数解释如下:
    Reset():
    将QueryRun对象qr的查询结果清零,游标(或者称为数据指针)指向初始位置,这样保证在下次运行qr.Next()时,重新执行SQL查询,获取新的数据集,在查询完毕后,游标指向返回结果集的第一条记录.
    如果想让一个QueryRun对象执行多次数据库查询,必须让让游标指向初始位置,这样qr在下次执行next()函数的时候才会知道要执行一次新的查询以便更新结果集,否则qr将不再执行新的查询动作.
  • 相关阅读:
    TP5.0 excel 导入导出
    整理关于web项目如何防止CSRF和XSS攻击的方法
    vue ajax获取数据的时候,如何保证传递参数的安全或者说如何保护api的安全
    vue.js打包后,接口安全问题
    JSON API免费接口
    tp5 $_ENV获取不到数据
    java cannot find the tag library descriptor for "http://java.sun.com/jsp/jstl/core"
    如何查找到文件以后,带目录一起拷贝到新的目录? cp --parents source destination
    台湾各个大学硕博论文链接,很全,有的可以全文下载。
    delete
  • 原文地址:https://www.cnblogs.com/Farseer1215/p/509546.html
Copyright © 2011-2022 走看看