皓学IT:WEB06_ EL表达式JSTL标签库

news2025/1/16 15:54:42

一、EL表达式

1.1.特点

  • 是一个由java开发的工具包

  • 用于从特定域对象中读取并写入到响应体开发任务,不能向域对象中写入。

  • EL工具包自动存在Tomcat的lib中(el-api.jar),开发是可以直接使用,无需其他额外的包。

  • 标准格式 : ${域对象别名.。关键字} 到指定的域中获取相应关键字的内容,并将其写入到响应体。

1.2.域对象

注:使用时可以省略域对象别名

默认查找顺序: pageScope -> requestScope -> sessionScope -> applicationScope

最好只在pageScope中省略

对应案例:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>jsp</title>
</head>
<body>
    <%
        application.setAttribute("name","applcation");
        session.setAttribute("name","session");
        request.setAttribute("name","request");
        pageContext.setAttribute("name","pageContext");
    %>
    <br>--------------使用java语言----------------<br>
    application中的值:<%= application.getAttribute("name")%><br>
    session中的值:<%= session.getAttribute("name")%><br>
    request中的值:<%= request.getAttribute("name")%><br>
    pageContext中的值:<%= pageContext.getAttribute("name")%><br>
​
    <br>--------------使用EL表达式----------------<br>
    application中的值:${applicationScope.name}<br>
    session中的值:${sessionScope.name}<br>
    request中的值:${requestScope.name}<br>
    pageContext中的值:${pageScope.name}<br>
​
    <br>--------------使用EL表达式,省略域对象----------------<br>
    application中的值:${name}<br>
</body>
</html>

 

1.3.支持的运算

(1)数学运算

(2)比较运算 > gt < lt >= ge <= le == eq != !=

(3)逻辑预算 && || !

对应案例:


<%@ page import="com.sun.org.apache.xpath.internal.operations.Bool" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>EL运算</title>
</head>
<body>
<%
    request.setAttribute("num1","12");
    request.setAttribute("num2","14");
​
    application.setAttribute("flag1",true);
    application.setAttribute("flag2",false);
%>
<br>---------------使用java语言-------------------<br>
<%
    String num1 = (String)request.getAttribute("num1");
    String num2 = (String)request.getAttribute("num2");
    int num3 = Integer.parseInt(num1)+Integer.parseInt(num2);
​
    boolean flag1 = (Boolean)application.getAttribute("flag1");
    boolean flag2 = (Boolean)application.getAttribute("flag2");
    boolean flag3 = flag1 && flag2;
​
    //输出方式一
    out.write(Boolean.toString(flag3));
%>
<!-- 输出方式二 -->
<h1><%=num3%></h1>
​
<br>---------------使用EL表达式-------------------<br>
<h1>${ requestScope.num1 + requestScope.num2 }</h1>
<h1>${ requestScope.num1 > requestScope.num2 }</h1>
<h1>${ applicationScope.flag1 && applicationScope.flag2 }</h1>
​
</body>
</html>

1.4.其他的内置对象

(1)param 使用 ${param.请求参数名} 从请求参数中获取参数内容

(2)paramValues 使用 ${ paramValues.请求参数名 } 从请求参数中获取多个值,以数组的形式

(3)initParam 使用 ${ initParam.参数名 } 获取初始化参数

<%@ page import="com.sun.org.apache.xpath.internal.operations.Bool" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>其他内置对象</title>
</head>
<body>
    url:...?username=zhangsan&password=admin<br>
    url中的参数:用户名:${param.username} --- 密码:${param.password}<br>
    -------------------------------------------<br>
    url:...?username=zhangsan&username=lisi
    url中的参数:用户1:${paramValues.username[0]} ---
               用户2:${paramValues.username[1]}<br>
    -------------------------------------------<br>
​
    <!--
        在web.xml中添加启动参数
        <context-param>
            <param-name>driver</param-name>
            <param-value>com.mysql.jdbc.Driver</param-value>
        </context-param>
    -->
    获取启动参数:${initParam.driver}
    
</body>
</html>

1.5.EL表达式的缺陷

(1)只能读取域对象中的值,不能写入

(2)不支持if判断和控制语句

二、 JSTL标签工具类

2.1.基本介绍

(1) JSP Standrad Tag Lib jsp标准标签库

(2) 是sun公司提供

(3) 组成

(4)使用原因:使用简单,且在JSP编程当中要求尽量不出现java代码

2.2.使用方式

(1)导入依赖的jar包 jstl.jar standard.jar

(2)在jsp中引入JSTL的core包依赖约束

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

2.3.重要标签的使用

2.3.1.<c: set>

在JSP文件上设置域对象中的共享数据

<%@ page import="com.sun.org.apache.xpath.internal.operations.Bool" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
    <title> c:set </title>
</head>
<body>
​
    <%--相当于
    <%
        request.setAttribute("name","zhangsan");
    %>
    --%>
    <c:set scope="request" var="name" value="zhangsan"/>
    通过JSTL添加的作用域的值:${requestScope.name} <br>
    <c:set scope="application" var="name" value="lisi"/>
    通过JSTL添加的作用域的值:${applicationScope.name} <br>
    <c:set scope="session" var="name" value="wangwu"/>
    通过JSTL添加的作用域的值:${sessionScope.name} <br>
    <c:set scope="page" var="name" value="zhaoliu"/>
    通过JSTL添加的作用域的值:${pageScope.name} <br>
​
</body>
</html>

2.3.2.<c: if>

控制哪些内容能够输出到响应体

<%@ page import="com.sun.org.apache.xpath.internal.operations.Bool" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
    <title> c:if </title>
</head>
    <c:set scope="page" var="age" value="20"/>
    <br>---------------使用java语言------------------<br>
    <%
        if(Integer.parseInt((String)pageContext.getAttribute("age")) >= 18){
    %>
    输入:欢迎光临!
    <%  }else{  %>
    输入:未满十八,禁止入内!
    <%  }  %>
    <br>---------------使用JSTL标签------------------<br>
    <c:if test="${age ge 18}">
        输入:欢迎光临!
    </c:if>
    <c:if test="${age lt 18}">
        输入:未满十八,禁止入内!
    </c:if>
​
</body>
</html>

2.3.3.<c: choose>

在jsp中进行多分支判断,决定哪个内容写入响应体

<%@ page import="com.sun.org.apache.xpath.internal.operations.Bool" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
    <title> c:choose </title>
</head>
<body>
    <c:set scope="page" var="age" value="20"/>
    <br>---------------使用java语言------------------<br>
    <%
        if(Integer.parseInt((String)pageContext.getAttribute("age")) == 18){
    %>
    输出:您今年成年了
    <%  }else if(Integer.parseInt((String)pageContext.getAttribute("age")) > 18){  %>
    输出:您已经成年了
    <%  }else{  %>
    输出:您还是个孩子
    <%  }  %>
    <br>---------------使用JSTL标签------------------<br>
    <c:choose>
        <c:when test="${age eq 18}">
            输出:您今年成年了
        </c:when>
        <c:when test="${age gt 18}">
            输出:您已经成年了
        </c:when>
        <c:otherwise>
            输出:您还是个孩子
        </c:otherwise>
    </c:choose>
​
</body>
</html>

2.3.4.<c: forEach>

循环遍历

<c:forEach var="申明循环变量的名称" begin="初始化循环变量"
           end="循环变量可以接受的最大值" step="循环变量的递增或递减值">
    *** step属性可以不写,默认递增1
    *** 循环变量默认保存在pageContext中
</c:forEach>
<%@ page import="java.util.ArrayList" %>
<%@ page import="java.util.HashMap" %>
<%@ page import="java.util.List" %>
<%@ page import="dao.Student" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
    <title> c:forEach </title>
</head>
<body>
    <%
        pageContext.setAttribute("students",new ArrayList(){{
            add(new Student("01","zhangsan",16));
            add(new Student("02","lisi",19));
            add(new Student("03","wangwu",15));
        }});
        pageContext.setAttribute("stuMap",new HashMap(){{
            put("s1",new Student("01","zhangsan",16));
            put("s2",new Student("02","zhangsan",19));
            put("s3",new Student("03","zhangsan",15));
        }});
    %>
    <br>---------------使用java语言----------------<br>
    <table>
        <tr><td>学号</td><td>姓名</td><td>年龄</td></tr>
        <%
            List<Student> students = (ArrayList<Student>)pageContext.getAttribute("students");
            for (int i = 0; i < students.size(); i++) {
        %>
        <tr>
            <td><%=students.get(i).getSid()%></td>
            <td><%=students.get(i).getName()%></td>
            <td><%=students.get(i).getAge()%></td>
        </tr>
        <%  }  %>
    </table>
    <br>---------------使用JSTL标签读取list----------------<br>
    <table>
        <tr><td>学号</td><td>姓名</td><td>年龄</td></tr>
        <c:forEach var="stu" items="${students}">
        <tr>
            <td>${stu.sid}</td>
            <td>${stu.name}</td>
            <td>${stu.age}</td>
        </tr>
        </c:forEach>
    </table>
    <br>---------------使用JSTL标签读取Map----------------<br>
    <table>
        <tr><td>key值</td><td>学号</td><td>姓名</td><td>年龄</td></tr>
        <c:forEach var="stu" items="${stuMap}">
            <tr>
                <td>${stu.key}</td>
                <td>${stu.value.sid}</td>
                <td>${stu.value.name}</td>
                <td>${stu.value.age}</td>
            </tr>
        </c:forEach>
    </table>
    <br>---------------使用JSTL标签读取指定for循环----------------<br>
    <c:forEach var="item" begin="1" end="10" step="1">
        <option> ${item} </option>
    </c:forEach>
</body>
</html>

其中使用的javaBean

public class Student {
    private String sid;
    private String name;
    private int age;
​
    public String getSid() {
        return sid;
    }
​
    public void setSid(String sid) {
        this.sid = sid;
    }
​
    public String getName() {
        return name;
    }
​
    public void setName(String name) {
        this.name = name;
    }
​
    public int getAge() {
        return age;
    }
​
    public void setAge(int age) {
        this.age = age;
    }
​
    public Student(String sid, String name, int age) {
        this.sid = sid;
        this.name = name;
        this.age = age;
    }
}

三、Listener、Filter

3.1.概念

  • servlet

servlet是一种运行服务器端的java应用程序,他可以用来处理请求和响应。

  • filter

过滤器,不像servlet,它不能产生一个请求或者响应,它是一个中间者,能修改处理经过它的请求和响应,并不能直接给客户端响应。

  • listener

监听器,它用来监听容器内的一些变化,如session的创建,销毁等。当变化产生时,监听器就要完成一些工作。

3.2.生命周期

1、servlet: servlet的生命周期始于它被装入web服务器的内存时,并在web服务器终止或重新装入servlet时结束。servlet一旦被装入web服务器,一般不会从web服务器内存中删除,直至web服务器关闭或重新开始。

1.装入:启动服务器时加载Servlet的实例;

2.初始化:web服务器启动时或web服务器接收到请求时,或者两者之间的某个时刻启动。初始化工作由init()方法负责执行完成;

3.调用:从第一次到以后的多次访问,都是只调用doGet()或doPost()方法;

4.销毁:停止服务器时调用destory()方法,销毁实例。

2、filter: 一定要实现javax.servlet包的Filter接口的三个方法init()、doFilter()、destory(),空实现也行

1.启动服务器时加载过滤器的实例,并调用init()方法来初始化实例;

2.每一次请求时都只调用方法doFilter()进行处理;

3.停止服务器时调用destory()方法,销毁实例。

3、listener: 类似于servlet和filter

servlet2.4规范中提供了8个listener接口,可以将其分为三类,分别如下:

  • 第一类:与servletContext有关的listener接口。包括:ServletContextListener、ServletContextAttributeListener;

  • 第二类:与HttpSession有关的Listener接口。包括:HttpSessionListener、HttpSessionAttributeListener、HttpSessionBindingListener、HttpSessionActivationListener;

  • 第三类:与ServletRequest有关的Listener接口,包括:ServletRequestListener、ServletRequestAttributeListener

web.xml 的加载顺序是:context- param -> listener -> filter -> servlet

3.3.使用方式

listener:

import javax.servlet.ServletRequestAttributeEvent;
import javax.servlet.ServletRequestAttributeListener;
import javax.servlet.ServletRequestEvent;
import javax.servlet.ServletRequestListener;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
​
public class TestListener implements HttpSessionListener, ServletRequestListener, ServletRequestAttributeListener {
    //sessionListener  start!
    @Override
    public void sessionCreated(HttpSessionEvent httpSessionEvent) {
        logger.info("............TestListener sessionCreated().............");
    }
​
    @Override
    public void sessionDestroyed(HttpSessionEvent httpSessionEvent) {
        logger.info("............TestListener sessionDestroyed().............");
    }
    //sessionListener end!
​
    //requestListener start!
    @Override
    public void requestInitialized(ServletRequestEvent servletRequestEvent) {
        logger.info("............TestListener requestInitialized().............");
    }
​
    @Override
    public void requestDestroyed(ServletRequestEvent servletRequestEvent) {
        logger.info("............TestListener requestDestroyed().............");
    }
    //requestListener end!
​
    //attributeListener start!
    @Override
    public void attributeAdded(ServletRequestAttributeEvent servletRequestAttributeEvent) {
        logger.info("............TestListener attributeAdded().............");
    }
​
    @Override
    public void attributeRemoved(ServletRequestAttributeEvent servletRequestAttributeEvent) {
        logger.info("............TestListener attributeRemoved().............");
    }
​
    @Override
    public void attributeReplaced(ServletRequestAttributeEvent servletRequestAttributeEvent) {
        logger.info("............TestListener attributeReplaced().............");
    }
    //attributeListener end!
​
​
​
}

Filter:

import javax.servlet.*;
import java.io.IOException;
​
public class TestFilter implements Filter {
​
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
​
    }
​
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        System.out.println("过滤器被执行了");
        //放行
        filterChain.doFilter(servletRequest,servletResponse);
    }
​
    @Override
    public void destroy() {
​
    }
}

Servlet:

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
​
public class TestServlet extends HttpServlet {
​
    @Override
    public void init() throws ServletException {
        super.init();
    }
​
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        super.doGet(req, resp);
    }
​
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        super.doPost(req, resp);
        //...TestdoPost  doPost()  start...
        //操作Attribute
        req.setAttribute("a","a");
        req.setAttribute("a","b");
        req.getAttribute("a");
        req.removeAttribute("a");
​
        //操作session
        req.getSession().setAttribute("a","a");
        req.getSession().getAttribute("a");
        req.getSession().invalidate();
        //...TestdoPost  doPost()  end...
    }
​
    @Override
    public void destroy() {
        super.destroy();
    }
​
}

配置XML

<!-- 测试filter -->
<filter>
    <filter-name>TestFilter</filter-name>
    <filter-class>test.TestFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>TestFilter</filter-name>
    <url-pattern>*.do</url-pattern>
</filter-mapping>
<!-- 测试servlet -->
<servlet>
    <servlet-name>TestServlet</servlet-name>
    <servlet-class>test.TestServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>TestServlet</servlet-name>
    <url-pattern>/*</url-pattern>
</servlet-mapping>
<!-- 测试listener -->
<listener>
    <listener-class>test.TestListener</listener-class>
</listener>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1539340.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

亚马逊云科技:企业如何开启生成式AI之旅?

如果要评选最近两年全球科技行业最热门的细分领域&#xff0c;那么生成式AI绝对会以遥遥领先的票数成为当仁不让的冠军。 然而眼见生成式AI发展得如火如荼&#xff0c;越来越多的企业却陷入了深深的焦虑&#xff1a;应该如何开启生成式AI之旅&#xff1f;又该怎样搭建大模型&am…

33-Java服务定位器模式 (Service Locator Pattern)

Java服务定位器模式 实现范例 服务定位器模式&#xff08;Service Locator Pattern&#xff09;用于想使用 JNDI 查询定位各种服务的时候考虑到为某个服务查找 JNDI 的代价很高&#xff0c;服务定位器模式充分利用了缓存技术在首次请求某个服务时&#xff0c;服务定位器在 JNDI…

网站引入 Prism,使得代码高亮显示,并一键复制代码块

曾几何时&#xff0c;苦恼如何将本地写好的博文&#xff0c;更好的展示读者屏幕前&#xff1f;若只是简简单单的文章&#xff0c;其实还是很好的解决它的&#xff01;可是&#xff0c;像我们这样写技术文章&#xff08;有点牵强&#xff09;的&#xff0c;在文章内容嵌入部分代…

【C++庖丁解牛】二叉搜索树(Binary Search Tree,BST)

&#x1f341;你好&#xff0c;我是 RO-BERRY &#x1f4d7; 致力于C、C、数据结构、TCP/IP、数据库等等一系列知识 &#x1f384;感谢你的陪伴与支持 &#xff0c;故事既有了开头&#xff0c;就要画上一个完美的句号&#xff0c;让我们一起加油 目录 1. 二叉搜索树概念2. 二叉…

IDEA 下载依赖包源码报错 Cannot download sources Sources not found for:XXX

最近在做一个功能的时候想看一个库的源码&#xff0c;结果源码下不下来&#xff0c;报Cannot download sources Sources not found for:XXX,网上搜了半天&#xff0c;也找不到靠谱的结论 后来想了下&#xff0c;应该是镜像那边出了问题&#xff0c;把镜像一删&#xff0c;源码…

EPO企业生产运营数智化平台助力制造企业迈向智能制造

随着“中国制造2025”和工业4.0的不断推进&#xff0c;越来越多的制造企业准备迈入智能制造和智慧制造领域&#xff0c;实现数智化管理。企业通过搭建EPO企业生产运营平台&#xff0c;结合自身业务现状和数字化需求&#xff0c;从各个业务场景、部门人员、产品组成等方面进行分…

(一)、Doris安装使用(基于Doris 2.0.6)

第 1 章Doris简介 1.1、 Doris 概述 ​ Apache Doris由百度大数据部研发&#xff08;之前叫百度 Palo&#xff0c;2018年贡献到 Apache 社区后&#xff0c;更名为 Doris&#xff09;&#xff0c;在百度内部&#xff0c;有超过200个产品线在使用&#xff0c;部署机器超过1000台…

国际品牌交期长 雷卯来帮忙

在当今的电子元器件市场中&#xff0c;防静电电子元器件的需求日益增长。无论是通信安防、医疗、消费类电子、照明行业、航空航天还是汽车电子等领域都会使用到防静电产品&#xff0c;使得防静电电子元器件的需求也呈现出爆发式的增长。在这一市场中&#xff0c;雷卯品牌凭借其…

Chain of Note-CoN增强检索增强型语言模型的鲁棒性

Enhancing Robustness in Retrieval-Augmented Language Models 检索增强型语言模型&#xff08;RALMs&#xff09;在大型语言模型的能力上取得了重大进步&#xff0c;特别是在利用外部知识源减少事实性幻觉方面。然而&#xff0c;检索到的信息的可靠性并不总是有保证的。检索…

六.排序nb三人组(快速排序)

目录 17-快速排序原理介绍 思路: 18-快速排序代码实现 19-快速排序代码实现2 缺点: 递归的限度: 17-快速排序原理介绍 思路: --先找一个变量把 5(第一个数) 存起来, (两个箭头分别是left , right) --左边有一个空位, 发现左边的位置是给比5小的值准备的. --找比5小的值…

算法体系-12 第 十二 二叉树的基本算法 下

一 实现二叉树的按层遍历 1.1 描述 1&#xff09;其实就是宽度优先遍历&#xff0c;用队列 2&#xff09;可以通过设置flag变量的方式&#xff0c;来发现某一层的结束&#xff08;看题目&#xff09;看下边的第四题解答 1.2 代码 public class Code01_LevelTraversalBT {publ…

【LabVIEW FPGA入门】FPGA不同传递数据方法比较

数据共享方法的选择应基于应用的需要。根据应用程序的重要特性&#xff0c;所讨论的任何一种方法都可能是合适的。 传输方法FPGA资源损耗&#xff1f;不同时钟源之间传递数据&#xff1f;新数据通知&#xff1f;常见用途变量逻辑片是是否提取最新数据存储器存储器是否否提取最新…

ubuntu20.04_PX4_1.13

说在前面&#xff1a;&#xff08;最好找一个干净的Ubuntu系统&#xff09;如果配置环境的过程中出现很多编译的错误或者依赖冲突&#xff0c;还是建议新建一个虚拟机&#xff0c;或者重装Ubuntu系统&#xff0c;这样会避免很多麻烦&#x1f490; &#xff0c; 安装PX4 1.13.2 …

学习刷题-12

3.22 hw机试【双指针】 Leetcode674 最长连续递增序列 给定一个未经排序的整数数组&#xff0c;找到最长且 连续递增的子序列&#xff0c;并返回该序列的长度。 双指针 一个慢指针一个快指针 慢指针记录递增子序列起点&#xff0c;快指针去寻找还在当前递增子序列的最后一…

Nutanix 国产化替代|一文了解 SmartX 超融合替代可行性与迁移方案

2022 年 8 月 19 日&#xff0c;Nutanix&#xff08;路坦力&#xff09;宣布中国市场自 2023 财年起将转型为合作伙伴销售主导模式&#xff0c;引起了广泛关注&#xff1b;同时结合当前 IT 基础架构的国产化趋势背景&#xff0c;不少正在使用和考虑使用 Nutanix 产品的企业开始…

基于Nvidia的ChatGPT实现智能回答(附完整代码)

目录 首先&#xff0c;我们需要在英伟达官网上找到相关的API-key 第二步&#xff0c;编写代码&#xff0c;调用API即可实现代码复用。 Python完整代码&#xff1a; Node版代码&#xff1a; Shell脚本代码&#xff1a; 最后我们在相应的编译器执行代码即可&#xff0c;在这里我们…

重学SpringBoot3-MyBatis的三种分页方式

更多SpringBoot3内容请关注我的专栏&#xff1a;《SpringBoot3》 期待您的点赞&#x1f44d;收藏⭐评论✍ 重学SpringBoot3-MyBatis的三种分页方式 准备工作环境搭建数据准备未分页效果 1. 使用MyBatis自带的RowBounds进行分页演示 2. 使用物理分页插件演示 3. 手动编写分页SQL…

软件测试-概念

衡量软件测试结果的依据--需求 需求的概念 满足用户期望或正式规定文档(合同, 规范, 标准)所具备的条件或权能, 包含用户需求和软件需求. IEEE:定义: 软件需求是(1)用户解决问题或达到目标所需的条件或权能. (2)系统或系统部件要满足合同, 标准, 规范或其它正式规定文档所具备…

MySQL、Oracle的时间类型字段自动更新:insert插入、update更新时,自动更新时间戳。设置自增主键id,oracle创建自增id序列和触发器

1. MySQL 支持设置自增id的字段类型&#xff1a;int、bigint、double等数值类型&#xff0c;一般用int、bigint支持设置自动更新时间的字段类型&#xff1a;datetime、timestamp下面sql中的now()函数可以用current_timestamp()替代 1.1. 不指定秒精度 drop table if exists …

一文读懂IP地址

IP地址&#xff08;Internet Protocol Address&#xff09;是指互联网协议地址&#xff0c;是IP协议提供的一种统一的地址格式&#xff0c;它为互联网上的每一个网络和每一台主机分配一个逻辑地址&#xff0c;以此来屏蔽物理地址的差异。IP地址的主要特点是具有唯一性&#xff…