2021-09-06

JSP九大内置对象和四大作用域

对象类型作用域
request 请求对象Request
response响应对象Page
pageContext页面上下文对象Page
session会话对象Session
application 应用程序对象Application
out输出对象Page
config 配置对象 Page
page页面对象Page
exception例外对象page

 

JSP九大对象:内置对象(又叫隐含对象,有9个内置对象):不需要预先声明就可以在脚本代码和表达式中随意使用。

一、request对象:代表的是来自客户端的请求,例如我们在FORM表单中填写的信息等,是最常用的对象。客户端的请求信息被封装在request对象中,通过它才能了解到客户的需求,然后做出响应。它是HttpServletRequest类的实例。作用域为request(用户请求期)。

常用方法:

   1 object getAttribute(String name) 返回指定属性的属性值 

  2 Enumeration getAttributeNames() 返回所有可用属性名的枚举 

  3 String getCharacterEncoding() 返回字符编码方式 

  4 int getContentLength() 返回请求体的长度(以字节数) 

  5 String getContentType() 得到请求体的MIME类型 

  6 ServletInputStream getInputStream() 得到请求体中一行的二进制流 

  7 String getParameter(String name) 返回name指定参数的参数值 

  8 Enumeration getParameterNames() 返回可用参数名的枚举 

  9 String[] getParameterValues(String name) 返回包含参数name的所有值的数组 

  10 String getProtocol() 返回请求用的协议类型及版本号 

  11 String getScheme() 返回请求用的计划名,如:http.https及ftp等 

  12 String getServerName() 返回接受请求的服务器主机名 

  13 int getServerPort() 返回服务器接受此请求所用的端口号 

  14 BufferedReader getReader() 返回解码过了的请求体 

  15 String getRemoteAddr() 返回发送此请求的客户端IP地址 

  16 String getRemoteHost() 返回发送此请求的客户端主机名 

  17 void setAttribute(String key,Object obj) 设置属性的属性值 

  18 String getRealPath(String path) 返回一虚拟路径的真实路径

二、response对象:对象代表的是对客户端的响应,也就是说可以通过response 对象来组织发送到客户端的数据。但是由于组织方式比较底层,所以不建议普通读者使用,需要向客户端发送文字时直接使用。它是HttpServletResponse类的实例。作用域为page(页面执行期)。

常用方法:

   1 String getCharacterEncoding() 返回响应用的是何种字符编码 

  2 ServletOutputStream getOutputStream() 返回响应的一个二进制输出流 

  3 PrintWriter getWriter() 返回可以向客户端输出字符的一个对象 

  4 void setContentLength(int len) 设置响应头长度 

  5 void setContentType(String type) 设置响应的MIME类型 

  6 sendRedirect(Java.lang.String location) 重新定向客户端的请求 

三、session对象:指的是客户端与服务器的一次会话,从客户连到服务器的一个WebApplication开始,直到客户端与服务器断开连接为止。它是HttpSession类的实例。作用域session(会话期—)。

常用方法:

    1 long getCreationTime() 返回SESSION创建时间 

  2 public String getId() 返回SESSION创建时JSP引擎为它设的惟一ID号 

  3 long getLastAccessedTime() 返回此SESSION里客户端最近一次请求时间 

  4 int getMaxInactiveInterval() 返回两次请求间隔多长时间此SESSION被取消(ms) 

  5 String[] getValueNames() 返回一个包含此SESSION中所有可用属性的数组 

  6 void invalidate() 取消SESSION,使SESSION不可用 

  7 boolean isNew() 返回服务器创建的一个SESSION,客户端是否已经加入 

  8 void removeValue(String name) 删除SESSION中指定的属性 

  9 void setMaxInactiveInterval() 设置两次请求间隔多长时间此SESSION被取消(ms)

四、out对象 :out对象是JspWriter类的实例,是向客户端输出内容常用的对象 。作用域为page(页面执行期)

常用方法:

    1 void clear() 清除缓冲区的内容 

  2 void clearBuffer() 清除缓冲区的当前内容 

  3 void flush() 清空流 

  4 int getBufferSize() 返回缓冲区以字节数的大小,如不设缓冲区则为0 

  5 int getRemaining() 返回缓冲区还剩余多少可用 

  6 boolean isAutoFlush() 返回缓冲区满时,是自动清空还是抛出异常 

  7 void close() 关闭输出流 

五、page对象:page对象就是指向当前JSP页面本身,有点象类中的this指针,它是java.lang.Object类的实例 。“page” 对象代表了正在运行的由JSP文件产生的类对象,不建议一般读者使用。 作用域    page

常用方法:

    1 class getClass 返回此Object的类 

  2 int hashCode() 返回此Object的hash码 

  3 boolean equals(Object obj) 判断此Object是否与指定的Object对象相等 

  4 void copy(Object obj) 把此Object拷贝到指定的Object对象中 

  5 Object clone() 克隆此Object对象 

  6 String toString() 把此Object对象转换成String类的对象 

  7 void notify() 唤醒一个等待的线程 

  8 void notifyAll() 唤醒所有等待的线程 

  9 void wait(int timeout) 使一个线程处于等待直到timeout结束或被唤醒 

  10 void wait() 使一个线程处于等待直到被唤醒 

  11 void enterMonitor() 对Object加锁 

  12 void exitMonitor() 对Object开锁

六、application对象:实现了用户间数据的共享,可存放全局变量。它开始于服务器的启动,直到服务器的关闭,在此期间,此对象将一直存在;这样在用户的前后连接或不同用户之间的连接中,可以对此对象的同一属性进行操作;在任何地方对此对象属性的操作,都将影响到其他用户对此的访问。服务器的启动和关闭决定了application对象的生命。它是ServletContext类的实例。作用域application

常用方法:

   1 Object getAttribute(String name) 返回给定名的属性值 

  2 Enumeration getAttributeNames() 返回所有可用属性名的枚举 

  3 void setAttribute(String name,Object obj) 设定属性的属性值 

  4 void removeAttribute(String name) 删除一属性及其属性值 

  5 String getServerInfo() 返回JSP(SERVLET)引擎名及版本号 

  6 String getRealPath(String path) 返回一虚拟路径的真实路径 

  7 ServletContext getContext(String uripath) 返回指定WebApplication的application对象 

  8 int getMajorVersion() 返回服务器支持的Servlet API的最大版本号 

  9 int getMinorVersion() 返回服务器支持的Servlet API的最大版本号 

  10 String getMimeType(String file) 返回指定文件的MIME类型 

  11 URL getResource(String path) 返回指定资源(文件及目录)的URL路径 

  12 InputStream getResourceAsStream(String path) 返回指定资源的输入流 

  13 RequestDispatcher getRequestDispatcher(String uripath) 返回指定资源的RequestDispatcher对象 

  14 Servlet getServlet(String name) 返回指定名的Servlet 

  15 Enumeration getServlets() 返回所有Servlet的枚举 

  16 Enumeration getServletNames() 返回所有Servlet名的枚举 

  17 void log(String msg) 把指定消息写入Servlet的日志文件 

  18 void log(Exception exception,String msg) 把指定异常的栈轨迹及错误消息写入Servlet的日志文件 

  19 void log(String msg,Throwable throwable) 把栈轨迹及给出的Throwable异常的说明信息 写入Servlet的日志文件 

七、pageContext对象提供了对JSP页面内所有的对象及名字空间的访问,也就是说他可以访问到本页所在的SESSION,也可以取本页面所在的application的某一属性值,他相当于页面中所有功能的集大成者,它的本类名也叫pageContext。用域    Pageconfig对象

常用方法:

    1 JspWriter getOut() 返回当前客户端响应被使用的JspWriter流(out) 

  2 HttpSession getSession() 返回当前页中的HttpSession对象(session) 

  3 Object getPage() 返回当前页的Object对象(page) 

  4 ServletRequest getRequest() 返回当前页的ServletRequest对象(request) 

  5 ServletResponse getResponse() 返回当前页的ServletResponse对象(response) 

  6 Exception getException() 返回当前页的Exception对象(exception) 

  7 ServletConfig getServletConfig() 返回当前页的ServletConfig对象(config) 

  8 ServletContext getServletContext() 返回当前页的ServletContext对象(application) 

  9 void setAttribute(String name,Object attribute) 设置属性及属性值 

  10 void setAttribute(String name,Object obj,int scope) 在指定范围内设置属性及属性值 

  11 public Object getAttribute(String name) 取属性的值 

  12 Object getAttribute(String name,int scope) 在指定范围内取属性的值 

  13 public Object findAttribute(String name) 寻找一属性,返回起属性值或NULL 

  14 void removeAttribute(String name) 删除某属性 

  15 void removeAttribute(String name,int scope) 在指定范围删除某属性 

  16 int getAttributeScope(String name) 返回某属性的作用范围 

  17 Enumeration getAttributeNamesInScope(int scope) 返回指定范围内可用的属性名枚举 

  18 void release() 释放pageContext所占用的资源 

  19 void forward(String relativeUrlPath) 使当前页面重导到另一页面 

  20 void include(String relativeUrlPath) 在当前位置包含另一文件 

八、config对象:config对象是在一个Servlet初始化时,JSP引擎向它传递信息用的,此信息包括Servlet初始化时所要用到的参数(通过属性名和属性值构成)以及服务器的有关信息(通过传递一个ServletContext对象)。作用域    Page

常用方法:

   1 ServletContext getServletContext() 返回含有服务器相关信息的ServletContext对象 

  2 String getInitParameter(String name) 返回初始化参数的值 

  3 Enumeration getInitParameterNames() 返回Servlet初始化所需所有参数的枚举

九、exception对象:是一个例外对象,当一个页面在运行过程中发生了例外,就产生这个对象。如果一个JSP页面要应用此对象,就必须把isErrorPage设为true,否则无法编译。他实际上是java.lang.Throwable的对象.作用域    page

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用python中的pymsql完成如下:表结构与数据创建 1. 建立 `users` 表和 `orders` 表。 `users` 表有用户ID、用户名、年龄字段,(id,name,age) `orders` 表有订单ID、订单日期、订单金额,用户id字段。(id,order_date,amount,user_id) 2 两表的id作为主键,`orders` 表用户id为users的外键 3 插入数据 `users` (1, '张三', 18), (2, '李四', 20), (3, '王五', 22), (4, '赵六', 25), (5, '钱七', 28); `orders` (1, '2021-09-01', 500, 1), (2, '2021-09-02', 1000, 2), (3, '2021-09-03', 600, 3), (4, '2021-09-04', 800, 4), (5, '2021-09-05', 1500, 5), (6, '2021-09-06', 1200, 3), (7, '2021-09-07', 2000, 1), (8, '2021-09-08', 300, 2), (9, '2021-09-09', 700, 5), (10, '2021-09-10', 900, 4); 查询语句 1. 查询订单总金额 2. 查询所有用户的平均年龄,并将结果四舍五入保留两位小数。 3. 查询订单总数最多的用户的姓名和订单总数。 4. 查询所有不重复的年龄。 5. 查询订单日期在2021年9月1日至9月4日之间的订单总金额。 6. 查询年龄不大于25岁的用户的订单数量,并按照降序排序。 7. 查询订单总金额排名前3的用户的姓名和订单总金额。 8. 查询订单总金额最大的用户的姓名和订单总金额。 9. 查询订单总金额最小的用户的姓名和订单总金额。 10. 查询所有名字中含有“李”的用户,按照名字升序排序。 11. 查询所有年龄大于20岁的用户,按照年龄降序排序,并只显示前5条记录。 12. 查询每个用户的订单数量和订单总金额,并按照总金额降序排序。
06-03
这里是使用 Python 的 PyMySQL 完成上述任务的代码: ```python import pymysql # 连接数据库 conn = pymysql.connect(host='localhost', port=3306, user='root', password='123456', database='test') # 创建游标 cur = conn.cursor() # 创建 users 表 cur.execute(''' CREATE TABLE users ( id INT PRIMARY KEY, name VARCHAR(20), age INT ) ''') # 创建 orders 表 cur.execute(''' CREATE TABLE orders ( id INT PRIMARY KEY, order_date DATE, amount INT, user_id INT, FOREIGN KEY (user_id) REFERENCES users(id) ) ''') # 插入数据 users_data = [ (1, '张三', 18), (2, '李四', 20), (3, '王五', 22), (4, '赵六', 25), (5, '钱七', 28) ] orders_data = [ (1, '2021-09-01', 500, 1), (2, '2021-09-02', 1000, 2), (3, '2021-09-03', 600, 3), (4, '2021-09-04', 800, 4), (5, '2021-09-05', 1500, 5), (6, '2021-09-06', 1200, 3), (7, '2021-09-07', 2000, 1), (8, '2021-09-08', 300, 2), (9, '2021-09-09', 700, 5), (10, '2021-09-10', 900, 4) ] for user in users_data: cur.execute('INSERT INTO users VALUES (%s, %s, %s)', user) for order in orders_data: cur.execute('INSERT INTO orders VALUES (%s, %s, %s, %s)', order) # 提交事务 conn.commit() # 查询语句 # 1. 查询订单总金额 cur.execute('SELECT SUM(amount) FROM orders') print(cur.fetchone()[0]) # 2. 查询所有用户的平均年龄,并将结果四舍五入保留两位小数。 cur.execute('SELECT ROUND(AVG(age), 2) FROM users') print(cur.fetchone()[0]) # 3. 查询订单总数最多的用户的姓名和订单总数。 cur.execute(''' SELECT users.name, COUNT(*) AS total_orders FROM users JOIN orders ON users.id = orders.user_id GROUP BY users.id ORDER BY total_orders DESC LIMIT 1 ''') print(cur.fetchone()) # 4. 查询所有不重复的年龄。 cur.execute('SELECT DISTINCT age FROM users') print([row[0] for row in cur.fetchall()]) # 5. 查询订单日期在2021年9月1日至9月4日之间的订单总金额。 cur.execute('SELECT SUM(amount) FROM orders WHERE order_date BETWEEN "2021-09-01" AND "2021-09-04"') print(cur.fetchone()[0]) # 6. 查询年龄不大于25岁的用户的订单数量,并按照降序排序。 cur.execute(''' SELECT users.name, COUNT(*) AS total_orders FROM users JOIN orders ON users.id = orders.user_id WHERE age <= 25 GROUP BY users.id ORDER BY total_orders DESC ''') print(cur.fetchall()) # 7. 查询订单总金额排名前3的用户的姓名和订单总金额。 cur.execute(''' SELECT users.name, SUM(amount) AS total_amount FROM users JOIN orders ON users.id = orders.user_id GROUP BY users.id ORDER BY total_amount DESC LIMIT 3 ''') print(cur.fetchall()) # 8. 查询订单总金额最大的用户的姓名和订单总金额。 cur.execute(''' SELECT users.name, SUM(amount) AS total_amount FROM users JOIN orders ON users.id = orders.user_id GROUP BY users.id ORDER BY total_amount DESC LIMIT 1 ''') print(cur.fetchone()) # 9. 查询订单总金额最小的用户的姓名和订单总金额。 cur.execute(''' SELECT users.name, SUM(amount) AS total_amount FROM users JOIN orders ON users.id = orders.user_id GROUP BY users.id ORDER BY total_amount ASC LIMIT 1 ''') print(cur.fetchone()) # 10. 查询所有名字中含有“李”的用户,按照名字升序排序。 cur.execute('SELECT * FROM users WHERE name LIKE "%李%" ORDER BY name ASC') print(cur.fetchall()) # 11. 查询所有年龄大于20岁的用户,按照年龄降序排序,并只显示前5条记录。 cur.execute('SELECT * FROM users WHERE age > 20 ORDER BY age DESC LIMIT 5') print(cur.fetchall()) # 12. 查询每个用户的订单数量和订单总金额,并按照总金额降序排序。 cur.execute(''' SELECT users.name, COUNT(*) AS total_orders, SUM(amount) AS total_amount FROM users JOIN orders ON users.id = orders.user_id GROUP BY users.id ORDER BY total_amount DESC ''') print(cur.fetchall()) # 关闭游标和连接 cur.close() conn.close() ``` 注意:在运行代码之前,需要先安装 PyMySQL 模块,可以使用以下命令进行安装: ``` pip install pymysql ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值