亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ordersgrid_jsp.java

?? 比較完整的網上書店系統
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
  }




static final String sFileName = "OrdersGrid.jsp";
              



  void Search_Show (javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response, javax.servlet.http.HttpSession session, javax.servlet.jsp.JspWriter out, String sSearchErr, String sForm, String sAction, java.sql.Connection conn, java.sql.Statement stat) throws java.io.IOException {
    try {
      

      String flditem_id="";
      String fldmember_id="";


      String sSQL="";
      String transitParams = "";
      String sQueryString = "";
      String sPage = "";
      

      out.println("    <table style=\"\">");
      
      out.println("     <form method=\"get\" action=\"OrdersGrid.jsp\" name=\"Search\">\n     <tr>");
      // Set variables with search parameters
      
      flditem_id = getParam( request, "item_id");
      fldmember_id = getParam( request, "member_id");

      // Show fields
      

      out.println("      <td style=\"background-color: #FFEAC5; border-style: inset; border-width: 0\"><font style=\"font-size: 10pt; color: #000000\">條目</font></td>");
      out.print("      <td style=\"background-color: #FFFFFF; border-width: 1\">"); 
      out.print("<select name=\"item_id\">"+getOptions( conn, "select item_id, name from items order by 2",true,false,flditem_id)+"</select>");
       out.println("</td>");
      
      out.println("      <td style=\"background-color: #FFEAC5; border-style: inset; border-width: 0\"><font style=\"font-size: 10pt; color: #000000\">會員</font></td>");
      out.print("      <td style=\"background-color: #FFFFFF; border-width: 1\">"); 
      out.print("<select name=\"member_id\">"+getOptions( conn, "select member_id, member_login from members order by 2",true,false,fldmember_id)+"</select>");
       out.println("</td>");
      
      out.println("      <td ><input type=\"submit\" value=\"搜索\"/></td>");
      out.println("     </tr>\n     </form>\n    </table>");
      out.println("");
    }
    catch (Exception e) { out.println(e.toString()); }
  }


  void Orders_Show (javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response, javax.servlet.http.HttpSession session, javax.servlet.jsp.JspWriter out, String sOrdersErr, String sForm, String sAction, java.sql.Connection conn, java.sql.Statement stat) throws java.io.IOException  {
  
    String sWhere = "";
    int iCounter=0;
    int iPage = 0;
    boolean bIsScroll = true;
    boolean hasParam = false;
    String sOrder = "";
    String sSQL="";
    String transitParams = "";
    String sQueryString = "";
    String sPage = "";
    int RecordsPerPage = 20;
    String sSortParams = "";
    String formParams = "";

      String pitem_id="";
      String pmember_id="";


    transitParams = "item_id=" + toURL(getParam( request, "item_id")) + "&member_id=" + toURL(getParam( request, "member_id")) + "&";
    formParams = "item_id=" + toURL(getParam( request, "item_id")) + "&member_id=" + toURL(getParam( request, "member_id")) + "&"; 
    // Build WHERE statement
        
    //-- Check item_id parameter and create a valid sql for where clause
  
    pitem_id = getParam( request, "item_id");
    if ( ! isNumber (pitem_id)) {
      pitem_id = "";
    }
    
    if (pitem_id != null && ! pitem_id.equals("")) {
            
        hasParam = true;
        sWhere += "o.item_id=" + pitem_id;
    }
    
    //-- Check member_id parameter and create a valid sql for where clause
  
    pmember_id = getParam( request, "member_id");
    if ( ! isNumber (pmember_id)) {
      pmember_id = "";
    }
    
    if (pmember_id != null && ! pmember_id.equals("")) {
            
      if (! sWhere.equals("")) sWhere += " and ";
        hasParam = true;
        sWhere += "o.member_id=" + pmember_id;
    }
    
    if (hasParam) { sWhere = " AND (" + sWhere + ")"; }
    // Build ORDER statement
    sOrder = " order by o.order_id Asc";
    String sSort = getParam( request, "FormOrders_Sorting");
    String sSorted = getParam( request, "FormOrders_Sorted");
    String sDirection = "";
    String sForm_Sorting = "";
    int iSort = 0;
    try {
      iSort = Integer.parseInt(sSort);
    }
    catch (NumberFormatException e ) {
      sSort = "";
    }
    if ( iSort == 0 ) {
      sForm_Sorting = "";
    }
    else {
      if ( sSort.equals(sSorted)) { 
        sSorted="0";
        sForm_Sorting = "";
        sDirection = " DESC";
        sSortParams = "FormOrders_Sorting=" + sSort + "&FormOrders_Sorted=" + sSort + "&";
      }
      else {
        sSorted=sSort;
        sForm_Sorting = sSort;
        sDirection = " ASC";
        sSortParams = "FormOrders_Sorting=" + sSort + "&FormOrders_Sorted=" + "&";
      }
    
      if ( iSort == 1) { sOrder = " order by i.name" + sDirection; }
      if ( iSort == 2) { sOrder = " order by m.member_login" + sDirection; }
      if ( iSort == 3) { sOrder = " order by o.quantity" + sDirection; }
    }
  

  // Build full SQL statement
  
  sSQL = "select o.item_id as o_item_id, " +
    "o.member_id as o_member_id, " +
    "o.order_id as o_order_id, " +
    "o.quantity as o_quantity, " +
    "i.item_id as i_item_id, " +
    "i.name as i_name, " +
    "m.member_id as m_member_id, " +
    "m.member_login as m_member_login " +
    " from orders o, items i, members m" +
    " where i.item_id=o.item_id and m.member_id=o.member_id  ";
  
  sSQL = sSQL + sWhere + sOrder;

  String sNoRecords = "     <tr>\n      <td colspan=\"4\" style=\"background-color: #FFFFFF; border-width: 1\"><font style=\"font-size: 10pt; color: #000000\">沒有記錄</font></td>\n     </tr>";


  String tableHeader = "";
      tableHeader = "     <tr>\n      <td style=\"background-color: #FFFFFF; border-style: inset; border-width: 0\"><a &\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">編輯</font></a></td>\n      <td style=\"background-color: #FFFFFF; border-style: inset; border-width: 0\"><a href=\""+sFileName+"?"+formParams+"FormOrders_Sorting=1&FormOrders_Sorted="+sSorted+"&\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">書名</font></a></td>\n      <td style=\"background-color: #FFFFFF; border-style: inset; border-width: 0\"><a href=\""+sFileName+"?"+formParams+"FormOrders_Sorting=2&FormOrders_Sorted="+sSorted+"&\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">會員</font></a></td>\n      <td style=\"background-color: #FFFFFF; border-style: inset; border-width: 0\"><a href=\""+sFileName+"?"+formParams+"FormOrders_Sorting=3&FormOrders_Sorted="+sSorted+"&\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">數量</font></a></td>\n     </tr>";
  
  
  try {
    out.println("    <table style=\"\">");
    out.println("     <tr>\n      <td style=\"background-color: #336699; text-align: Center; border-style: outset; border-width: 1\" colspan=\"4\"><a name=\"Orders\"><font style=\"font-size: 12pt; color: #FFFFFF; font-weight: bold\">訂單</font></a></td>\n     </tr>");
    out.println(tableHeader);

  }
  catch (Exception e) {}

  
  try {
    // Select current page
    iPage = Integer.parseInt(getParam( request, "FormOrders_Page"));
  }
  catch (NumberFormatException e ) {
    iPage = 0;
  }

  if (iPage == 0) { iPage = 1; }
  RecordsPerPage = 20;
  try {
    java.sql.ResultSet rs = null;
    // Open recordset
    rs = openrs( stat, sSQL);
    iCounter = 0;
    absolute (rs, (iPage-1)*RecordsPerPage+1);
    java.util.Hashtable rsHash = new java.util.Hashtable();
    String[] aFields = getFieldsName( rs );

    // Show main table based on recordset
    while ( (iCounter < RecordsPerPage) && rs.next() ) {

      getRecordToHash( rs, rsHash, aFields );
      String flditem_id = (String) rsHash.get("i_name");
      String fldmember_id = (String) rsHash.get("m_member_login");
      String fldorder_id = (String) rsHash.get("o_order_id");
      String fldquantity = (String) rsHash.get("o_quantity");
      String fldField1= "Edit";

      out.println("     <tr>");
      
      out.print("      <td style=\"background-color: #FFFFFF; border-width: 1\">"); out.print("<a href=\"OrdersRecord.jsp?"+transitParams+"order_id="+toURL((String) rsHash.get("o_order_id"))+"&\"><font style=\"font-size: 10pt; color: #000000\">"+toHTML(fldField1)+"</font></a>");

      out.println("</td>");
      out.print("      <td style=\"background-color: #FFFFFF; border-width: 1\">"); out.print("<font style=\"font-size: 10pt; color: #000000\">"+toHTML(flditem_id)+"&nbsp;</font>");
      out.println("</td>");
      out.print("      <td style=\"background-color: #FFFFFF; border-width: 1\">"); out.print("<font style=\"font-size: 10pt; color: #000000\">"+toHTML(fldmember_id)+"&nbsp;</font>");
      out.println("</td>");
      out.print("      <td style=\"background-color: #FFFFFF; border-width: 1\">"); out.print("<font style=\"font-size: 10pt; color: #000000\">"+toHTML(fldquantity)+"&nbsp;</font>");
      out.println("</td>");
      out.println("     </tr>");
    
      iCounter++;
    }
    if (iCounter == 0) {
      // Recordset is empty
      out.println(sNoRecords);
    
      out.print("     <tr>\n      <td colspan=\"4\" style=\"background-color: #FFFFFF; border-style: inset; border-width: 0\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">");
      out.print("<a href=\"OrdersRecord.jsp?"+formParams+"\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">插入</font></a>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;");
      out.println("</td>\n     </tr>");
    
      iCounter = RecordsPerPage+1;
      bIsScroll = false;
    }

    else {

  
    // Parse scroller
    boolean bInsert = false;
    boolean bNext = rs.next();
    if ( !bNext && iPage == 1 ) {
    
      out.print("     <tr>\n      <td colspan=\"4\" style=\"background-color: #FFFFFF; border-style: inset; border-width: 0\">\n       <font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">");
      out.print("\n        <a href=\"OrdersRecord.jsp?"+formParams+"\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">插入</font></a>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;");
      out.println("\n      </td>\n     </tr>");
    
    }
    else {
      out.print("     <tr>\n      <td colspan=\"4\" style=\"background-color: #FFFFFF; border-style: inset; border-width: 0\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">");
    
      out.print("\n       <a href=\"OrdersRecord.jsp?"+formParams+"\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">Insert</font></a>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;");
      bInsert = true;
    
      if ( iPage == 1 ) {
        out.print("\n       <a href_=\"#\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">向前</font></a>");
      }
      else {
        out.print("\n       <a href=\""+sFileName+"?"+formParams+sSortParams+"FormOrders_Page="+(iPage - 1)+"#Form\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">向前</font></a>");
      }
  
      out.print("\n       [ "+iPage+" ]");
  
      if (!bNext) { 
        out.print("\n       <a href_=\"#\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">下一個</font></a><br>");
      }
      else {
        out.print("\n       <a href=\""+sFileName+"?"+formParams+sSortParams+"FormOrders_Page="+(iPage + 1)+"#Form\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">下一個</font></a><br>");
      }
    
      if ( ! bInsert ) {
        out.print("     <tr>\n      <td colspan=\"4\" style=\"background-color: #FFFFFF; border-style: inset; border-width: 0\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">");
        out.print("\n        <a href=\"OrdersRecord.jsp?"+formParams+"\"><font style=\"font-size: 10pt; color: #CE7E00; font-weight: bold\">Insert</font></a>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;");
      }
    
      out.println("</td>\n     </tr>");
    }
  
    }

    if ( rs != null ) rs.close();
    out.println("    </table>");
    
  }
  catch (Exception e) { out.println(e.toString()); }
}

  private static java.util.Vector _jspx_dependants;

  static {
    _jspx_dependants = new java.util.Vector(1);
    _jspx_dependants.add("/pages/Common.jsp");
  }

  public java.util.List getDependants() {
    return _jspx_dependants;
  }

  public void _jspService(HttpServletRequest request, HttpServletResponse response)
        throws java.io.IOException, ServletException {

    JspFactory _jspxFactory = null;
    PageContext pageContext = null;
    HttpSession session = null;
    ServletContext application = null;
    ServletConfig config = null;
    JspWriter out = null;
    Object page = this;
    JspWriter _jspx_out = null;
    PageContext _jspx_page_context = null;


    try {
      _jspxFactory = JspFactory.getDefaultFactory();
      response.setContentType("text/html;charset=gb2312");
      pageContext = _jspxFactory.getPageContext(this, request, response,
      			null, true, 8192, true);
      _jspx_page_context = pageContext;
      application = pageContext.getServletContext();
      config = pageContext.getServletConfig();
      session = pageContext.getSession();
      out = pageContext.getOut();
      _jspx_out = out;

      out.write('\r');
      out.write('\n');


String cSec = checkSecurity(2, session, response, request);
if ("sendRedirect".equals(cSec) ) return;
                
boolean bDebug = false;

String sAction = getParam( request, "FormAction");
String sForm = getParam( request, "FormName");
String sSearchErr = "";
String sOrdersErr = "";

java.sql.Connection conn = null;
java.sql.Statement stat = null;
String sErr = loadDriver();
conn = cn();
stat = conn.createStatement();
if ( ! sErr.equals("") ) {
 try {
   out.println(sErr);
 }
 catch (Exception e) {}
}


      out.write("            \r\n");
      out.write("<html>\r\n");
      out.write("<head>\r\n");
      out.write("<title>Book Store</title>\r\n");
      out.write("<meta name=\"GENERATOR\" content=\"YesSoftware CodeCharge v.1.2.0 / JSP.ccp build 05/21/2001\"/>\r\n");
      out.write("<meta http-equiv=\"pragma\" content=\"no-cache\"/>\r\n");
      out.write("<meta http-equiv=\"expires\" content=\"0\"/>\r\n");
      out.write("<meta http-equiv=\"cache-control\" content=\"no-cache\"/>\r\n");
      out.write("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=ISO-8859-1\">\r\n");
      out.write("</head>\r\n");
      out.write("<body style=\"background-color: #FFFFFF; color: #000000; font-family: Arial, Tahoma, Verdana, Helveticabackground-color: #FFFFFF; color: #000000; font-family: Arial, Tahoma, Verdana, Helvetica\">\r\n");
      org.apache.jasper.runtime.JspRuntimeLibrary.include(request, response, "Header.jsp", out, true);
      out.write("\r\n");
      out.write(" <table>\r\n");
      out.write("  <tr>\r\n");
      out.write("   \r\n");
      out.write("   <td valign=\"top\">\r\n");
 Search_Show(request, response, session, out, sSearchErr, sForm, sAction, conn, stat); 
      out.write("\r\n");
      out.write("    \r\n");
      out.write("   </td>\r\n");
      out.write("  </tr>\r\n");
      out.write(" </table>\r\n");
      out.write(" <table>\r\n");
      out.write("  <tr>\r\n");
      out.write("   <td valign=\"top\">\r\n");
 Orders_Show(request, response, session, out, sOrdersErr, sForm, sAction, conn, stat); 
      out.write("\r\n");
      out.write("    \r\n");
      out.write("   </td>\r\n");
      out.write("  </tr>\r\n");
      out.write(" </table>\r\n");
      out.write("\r\n");
      org.apache.jasper.runtime.JspRuntimeLibrary.include(request, response, "Footer.jsp", out, true);
      out.write("\r\n");
      out.write("</body>\r\n");
      out.write("</html>\r\n");

      out.write('\r');
      out.write('\n');

if ( stat != null ) stat.close();
if ( conn != null ) conn.close();

      out.write('\r');
      out.write('\n');
    } catch (Throwable t) {
      if (!(t instanceof SkipPageException)){
        out = _jspx_out;
        if (out != null && out.getBufferSize() != 0)
          out.clearBuffer();
        if (_jspx_page_context != null) _jspx_page_context.handlePageException(t);
      }
    } finally {
      if (_jspxFactory != null) _jspxFactory.releasePageContext(_jspx_page_context);
    }
  }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩在线免费视频| 国产精品丝袜一区| 成人ar影院免费观看视频| 日韩和欧美一区二区| 国产精品一区在线观看乱码| 91黄色小视频| 久久久精品天堂| 蜜臀久久久久久久| 欧美性三三影院| 自拍偷自拍亚洲精品播放| 狠狠色丁香婷婷综合| 欧美日本在线播放| 亚洲精品伦理在线| 成人国产在线观看| 久久久久国产精品免费免费搜索| 日韩影院精彩在线| 欧美日韩一区精品| 亚洲国产精品久久人人爱| 不卡av在线免费观看| 亚洲国产精品精华液ab| 国产一区二区看久久| 欧美成人官网二区| 日韩二区在线观看| 欧美日韩国产高清一区二区三区| 悠悠色在线精品| 色综合久久久久久久久| 亚洲人成电影网站色mp4| 99r精品视频| 中文字幕一区二区在线观看| 成人黄动漫网站免费app| 国产精品女同一区二区三区| 成a人片亚洲日本久久| 亚洲欧美日本在线| 在线精品观看国产| 午夜日韩在线电影| 欧美高清激情brazzers| 久久精品久久综合| 精品对白一区国产伦| 懂色av一区二区三区免费看| 中文字幕第一页久久| 色偷偷成人一区二区三区91 | 欧美影视一区二区三区| 亚洲视频精选在线| 日本黄色一区二区| 午夜精品aaa| 日韩女优制服丝袜电影| 国产一区二区三区四区五区美女 | 日韩欧美一区二区不卡| 国产美女久久久久| 亚洲三级免费电影| 欧美精品视频www在线观看| 蜜桃传媒麻豆第一区在线观看| 日韩视频一区二区三区| 国产成人在线影院| 亚洲黄色尤物视频| 欧美日韩国产精品成人| 国精品**一区二区三区在线蜜桃| 中文字幕av不卡| 欧美制服丝袜第一页| 秋霞午夜鲁丝一区二区老狼| 久久男人中文字幕资源站| 91色九色蝌蚪| 免费av网站大全久久| 国产精品热久久久久夜色精品三区| 欧美本精品男人aⅴ天堂| 东方欧美亚洲色图在线| 亚欧色一区w666天堂| 久久精品免视看| 欧美日韩精品欧美日韩精品| 国产美女在线精品| 亚洲成人高清在线| 久久久777精品电影网影网 | www.成人网.com| 日韩—二三区免费观看av| 国产精品情趣视频| 日韩精品中文字幕一区| 在线亚洲+欧美+日本专区| 国产成人精品一区二区三区网站观看| 一区二区三区国产| 国产视频一区二区在线| 欧美色大人视频| 99精品视频一区| 国产精品亚洲第一区在线暖暖韩国| 亚洲风情在线资源站| 亚洲同性gay激情无套| 国产亚洲污的网站| 日韩一区二区三区四区| 在线观看日韩电影| 成人不卡免费av| 狠狠色综合色综合网络| 天堂一区二区在线| 亚洲激情综合网| 综合激情成人伊人| 欧美国产欧美综合| 久久久久国产精品人| 欧美一级黄色大片| 精品视频在线免费| 欧美羞羞免费网站| av亚洲精华国产精华| 国产白丝网站精品污在线入口| 免费三级欧美电影| 日韩成人av影视| 亚洲第一综合色| 亚洲一二三四区| 亚洲另类色综合网站| 国产精品丝袜一区| 中文子幕无线码一区tr | 欧美日韩小视频| 欧美午夜宅男影院| 欧美日韩一区久久| 91精品国产aⅴ一区二区| 欧洲色大大久久| 欧美日韩和欧美的一区二区| 欧美最猛性xxxxx直播| 日本高清成人免费播放| 日本高清不卡视频| 欧美久久久久免费| 91精品国产综合久久精品| 日韩美女在线视频| 久久色中文字幕| 国产精品理伦片| 亚洲一区在线观看网站| 天天操天天综合网| 精品在线一区二区三区| 国产成人av自拍| 日本韩国欧美在线| 7777精品伊人久久久大香线蕉超级流畅 | 亚洲欧洲性图库| 一级女性全黄久久生活片免费| 亚洲一区二区三区自拍| 日韩av不卡一区二区| 久草热8精品视频在线观看| 国产精品一区二区无线| 色综合天天天天做夜夜夜夜做| 欧美中文字幕一区| 精品电影一区二区| 国产精品久久久久久久裸模| 亚洲线精品一区二区三区| 秋霞午夜av一区二区三区| 丁香亚洲综合激情啪啪综合| 色婷婷综合久久久中文一区二区 | 色婷婷国产精品久久包臀| 欧美美女bb生活片| 久久精品视频在线看| 一区二区三区在线观看欧美| 日韩高清电影一区| 成人少妇影院yyyy| 欧美一区二区三区精品| 国产精品免费av| 丝袜亚洲精品中文字幕一区| 国产传媒日韩欧美成人| 91久久国产综合久久| 精品久久久久久最新网址| 亚洲精品国产第一综合99久久| 日韩精品一级二级| 99国产欧美久久久精品| 欧美一卡二卡三卡| 亚洲乱码国产乱码精品精小说 | 91国偷自产一区二区开放时间 | 国产精品久久福利| 夜夜精品浪潮av一区二区三区| 日本中文字幕一区| 99久久综合狠狠综合久久| 欧美成人三级电影在线| 一区二区三区在线免费| 国产成人av福利| 91精品国产综合久久久久久久| 国产精品灌醉下药二区| 狠狠色丁香婷婷综合久久片| 欧美三级中文字幕| 最新热久久免费视频| 精品写真视频在线观看| 在线成人免费视频| 亚洲男人的天堂av| 成人黄色片在线观看| 久久久久久综合| 美腿丝袜一区二区三区| 欧美男生操女生| 一区二区三区久久| 99久久久国产精品| 国产精品久久久久久久裸模| 精品在线免费视频| 日韩一区二区在线观看视频 | 国产电影一区二区三区| 欧美一卡二卡在线| 视频一区二区不卡| 欧美伦理视频网站| 亚洲国产综合在线| 欧美午夜电影在线播放| **网站欧美大片在线观看| 成人黄色在线视频| 国产欧美综合在线观看第十页| 国产一区二区三区免费看| 日韩精品一区二区三区中文不卡 | 亚洲一区二区偷拍精品| 在线日韩av片| 亚洲电影第三页| 欧美老肥妇做.爰bbww| 五月婷婷激情综合网| 宅男在线国产精品|