Eight of JavaJSP Learning Series (rewriting the Mysql floppage example)

zhaozj2021-02-16  51

I. Introduction

In fact, the rewritten JDBC Data-Source is running in the servlet, looking for the data source via JNDI. I use Orion to try this site "Java / JSP learning series (MySQL floppage example)" simply rewritten.

Second, the configuration

(1) JDBC

Need to use the JDBC driver COPY to [Orion] / lib directory

(2) Data-Source

Add below in the [Orion] /config/data-sources.xml file:

Class = "com.evermind.sql.drivermanagerDataSource"

Name = "mysqldbpage"

Location = "JDBC / HYPERSONICCOREDS"

XA-location = "JDBC / XA / HypersonicxADS"

ejb-location = "jdbc / mysqldbpage"

Connection-Driver = "org.gjt.mm.mysql.driver"

Username = "root"

PASSWORD = ""

URL = "JDBC: mysql: // localhost / test"

INACTIVITY-TIMEOUT = "30"

/>

have to be aware of is:

(1) EJB-LOCATION This "JDBC / MySQLDBPAGE" later is JNDI to find.

(2) Connection-Driver drives the JDBC database

(3) URL is the URL in JDBC

(4) Username is the database username

(5) Password is the user password

(6) INACTIVITY-TIMEOUT for database connection timeout, default is 30 seconds

Do not change for other places.

Third, the changed code is as follows:

<% @ Page ContentType = "text / html; charset = GB2312"%>

<% @ page import = "java.sql. *, javax.sql.datasource, javax.naming.initialcontext"%>

<%

// Create a JNDI lookup object

InitialContext JNDI_CONTEXT = New InitialContext ();

// jndi lookup data source

DataSource DS = (DataSource) JNDI_CONTEXT.LOOKUP ("JDBC / MySqldbpage");

// Get a data source connection

Connection conn = ds.getConnection ();

INT INTPAGESIZE; / / One page shows the number of records

INT INTROWCOUNT; // Total number of records

INT INTPAGECUNT; / / Total number of pages

INT INTPAGE; // Waiting page number

Java.lang.string strpage;

INT I;

/ / Set the number of records displayed

INTPAGESIZE = 2;

/ / Get the page number to be displayed

StrPage = Request.getParameter ("Page");

IF (strpage == null) {

// Indicates that there is no Page this parameter in querystring, and the first page is displayed.

INTPAGE = 1;

} else {

/ / Convert the string to integer

INTPAGE = java.lang.integer.parseint (STRPAGE);

IF (INTPAGE <1) INTPAGE = 1;}

// got the answer

STMT = conn.createstatement ();

ResultSet Sqlrst = Stmt.executeQuery ("SELECT F1 from Test");

// Get the total number of records

Sqlrst.last ();

introwcount = sqlrst.getrow ();

// Mode total page

INTPAGECOUNT = (Introwcount INTPAGESIZE-1) / INTPAGESIZE

// Adjust the page number to be displayed

IF (INTPAGE> INTPAGECOUNT)

INTPAGE = INTPAGECOUNT;

%>

JSP database operation routine - Data page display - JDBC 2.0 - MySQL </ Title></p> <p></ hEAD></p> <p><body></p> <p><table border = "1" cellspacing = "0" Cellpadding = "0"></p> <p><tr></p> <p><TH> Name </ TH></p> <p></ TR></p> <p><% IF (INTPAGECUNT> 0)</p> <p>{</p> <p>// Position the record pointer to the first record of the page to be displayed</p> <p>Sqlrst.absolute (INTPAGE-1) * INTPAGESIZE 1);</p> <p>//Display Data</p> <p>i = 0;</p> <p>While (i <intpagesize&&! sqlrst.isafterlast ()) {%></p> <p><tr></p> <p><TD></p> <p><% = sqlrst.getstring (1)%></p> <p></ td></p> <p></ TR></p> <p><% SQLRST.NEXT ();</p> <p>i ;</p> <p>}</p> <p>}</p> <p>%></p> <p></ TABLE></p> <p>No. <% = intPage%> page a total of <% = INTPAGECOUNT%> page</p> <p><% IF (INTPAGE <INTPAGECOUNT) {%> <a href="mysqlpage.jsp?page=< =intpage 1% "> Next page </a> <%}%></p> <p><% IF (INTPAGE> 1) {%> <a href="mysqlpage.jsp?page=<%=intpage-1% "> Previous </a> <%}%></p> <p></ body></p> <p></ html></p> <p><%</p> <p>// Close the result set</p> <p>Sqlrst.close ();</p> <p>%></p> <p>Third, how can I run?</p> <p>See the "JAVA / JSP Learning Series" five (JDBC-ODBC flip examples).</p> <p>Note: MySQL database is TEST, there is a table test in the middle, there is a field F1 (varchar)</p></div><div class="text-center mt-3 text-grey"> 转载请注明原文地址:https://www.9cbs.com/read-19788.html</div><div class="plugin d-flex justify-content-center mt-3"></div><hr><div class="row"><div class="col-lg-12 text-muted mt-2"><i class="icon-tags mr-2"></i><span class="badge border border-secondary mr-2"><h2 class="h6 mb-0 small"><a class="text-secondary" href="tag-2.html">9cbs</a></h2></span></div></div></div></div><div class="card card-postlist border-white shadow"><div class="card-body"><div class="card-title"><div class="d-flex justify-content-between"><div><b>New Post</b>(<span class="posts">0</span>) </div><div></div></div></div><ul class="postlist list-unstyled"> </ul></div></div><div class="d-none threadlist"><input type="checkbox" name="modtid" value="19788" checked /></div></div></div></div></div><footer class="text-muted small bg-dark py-4 mt-3" id="footer"><div class="container"><div class="row"><div class="col">CopyRight © 2020 All Rights Reserved </div><div class="col text-right">Processed: <b>0.047</b>, SQL: <b>9</b></div></div></div></footer><script src="./lang/en-us/lang.js?2.2.0"></script><script src="view/js/jquery.min.js?2.2.0"></script><script src="view/js/popper.min.js?2.2.0"></script><script src="view/js/bootstrap.min.js?2.2.0"></script><script src="view/js/xiuno.js?2.2.0"></script><script src="view/js/bootstrap-plugin.js?2.2.0"></script><script src="view/js/async.min.js?2.2.0"></script><script src="view/js/form.js?2.2.0"></script><script> var debug = DEBUG = 0; var url_rewrite_on = 1; var url_path = './'; var forumarr = {"1":"Tech"}; var fid = 1; var uid = 0; var gid = 0; xn.options.water_image_url = 'view/img/water-small.png'; </script><script src="view/js/wellcms.js?2.2.0"></script><a class="scroll-to-top rounded" href="javascript:void(0);"><i class="icon-angle-up"></i></a><a class="scroll-to-bottom rounded" href="javascript:void(0);" style="display: inline;"><i class="icon-angle-down"></i></a></body></html><script> var forum_url = 'list-1.html'; var safe_token = 'JEseMfzr3eEBohFGHJKpc6_2FKbSkri373flvE1giX9Lfgw0BOCdsh7FRLcA6KdoDwWmPv9qwR_2Bp_2BS8zHI'; var body = $('body'); body.on('submit', '#form', function() { var jthis = $(this); var jsubmit = jthis.find('#submit'); jthis.reset(); jsubmit.button('loading'); var postdata = jthis.serializeObject(); $.xpost(jthis.attr('action'), postdata, function(code, message) { if(code == 0) { location.reload(); } else { $.alert(message); jsubmit.button('reset'); } }); return false; }); function resize_image() { var jmessagelist = $('div.message'); var first_width = jmessagelist.width(); jmessagelist.each(function() { var jdiv = $(this); var maxwidth = jdiv.attr('isfirst') ? first_width : jdiv.width(); var jmessage_width = Math.min(jdiv.width(), maxwidth); jdiv.find('img, embed, iframe, video').each(function() { var jimg = $(this); var img_width = this.org_width; var img_height = this.org_height; if(!img_width) { var img_width = jimg.attr('width'); var img_height = jimg.attr('height'); this.org_width = img_width; this.org_height = img_height; } if(img_width > jmessage_width) { if(this.tagName == 'IMG') { jimg.width(jmessage_width); jimg.css('height', 'auto'); jimg.css('cursor', 'pointer'); jimg.on('click', function() { }); } else { jimg.width(jmessage_width); var height = (img_height / img_width) * jimg.width(); jimg.height(height); } } }); }); } function resize_table() { $('div.message').each(function() { var jdiv = $(this); jdiv.find('table').addClass('table').wrap('<div class="table-responsive"></div>'); }); } $(function() { resize_image(); resize_table(); $(window).on('resize', resize_image); }); var jmessage = $('#message'); jmessage.on('focus', function() {if(jmessage.t) { clearTimeout(jmessage.t); jmessage.t = null; } jmessage.css('height', '6rem'); }); jmessage.on('blur', function() {jmessage.t = setTimeout(function() { jmessage.css('height', '2.5rem');}, 1000); }); $('#nav li[data-active="fid-1"]').addClass('active'); </script>