- JavaWeb编程实战宝典(5)___ 第5章 编写Struts2第一个程序
岁月静好浅笑安然
第5章编写Struts2第一个程序5.1Struts2的MVC模式Struts2中的控制器主要有如下4个功能简单验证复制验证商业逻辑流控制Struts2框架结构可分为以下4部分JSP/Struts2标签(视图层V层)ActionSupport的子类(控制层C层)处理业务逻辑和数据逻辑的JavaBean(模型层M层)用于保存Struts2配置的struts.xml文件5.2Struts2的结构体系5
- Action获取表单提交数据的三种方式
活着_3840
(1)使用ActionContext类范例:form.jspusename:password:配置struts.xml使用第一种方法:使用ActionConext来获取publicclassFormAcrionextendsActionSupport{ActionContextcontext=ActionContext.getContext();Mapmap=context.getParamter
- eclipse搭建struts2环境及所遇到的问题
andunxu1008
java开发工具
最近几天一直在搭建struts2框架,本身struts2框架的搭建是非常简单的,但不知道为什么最近就是总是报错,报了一大串的错首先就是每次在类的根路径下创建struts.xml时,就报错,也不知道为什么,我还把eclipse换了一遍,结果没错了,我也是非常纳闷。报的是:Theerrorsbelowweredetectedwhenvalidatingthefile"struts-2.3.dtd"vi
- 使用预定义的token拦截器
黎涛note
•token拦截器用于解决表单的重复提交。•使用步骤:1、在表单所在的JSP页面中使用标签;该标签可生成token值;注意:当你在表单所在的JSP页面中使用标签进行配置之后,会出现两个隐藏的标签:value="CLH6JFX8DFWHLLSKUDRZ1A8M1X3AL5X9"就是token拦截器生成的令牌2、在struts.xml中配置token拦截器;该拦截器自动检查token值是否一致,通常将
- Java Struts2 doubleselect实现省市级联下拉框
帅龍之龍
#SSH古董框架Java
在Struts2中,给我们提供了一个s:doubleselect标签,该标签可以实现级联下拉选择。doubleselect.jspDocumentselect{width:200px;height:40px;}result.jspDocument,struts.xml/doubleselect.jsp/result.jspweb.xmldoubleselect.jspstruts2org.apac
- Java 使用Struts2框架创建一个HelloWorld
帅龍之龍
Java#SSH古董框架
我的运行配置JDK:jdk1.8.0_91服务器:apache-tomcat-7.0.81IDE:MyEclipse10首先新建WebProject向项目添加struts2容器(此时项目已经有了Struts2CoreLibraries库,src目录下自动生成struts.xml)在src目录下新建一个类HelloWorldAction,包名如:top.k10000HelloWorldAction.
- struts2修改文件上传的大小
huangxr874668739
Struts2拦截器修改上传文件大小上传文件大小struts上传文件大小
转自:https://www.cnblogs.com/yaobolove/p/5241988.html那天写了一个web上传图片的程序,明明修改了上传文件的默认值(2M),可就是一直没有起作用image/png,image/gif,image/jpeg,image/jpg,image/x-png102400000原来上网查了一下,还要加入这个东西在struts.xml中加入,大约10M才能使拦截器
- Struts2
Ew0828
1.捕捉异常在Struts-default.xml中配置是否开启Struts2的异常映射(配置了一个拦截器)默认情况下,该拦截器是打开的如何完成异常处理?在struts.xml中通过标签完成该标签有两个两个属性:(1)exception:用于指定可以处理哪一类异常,其值为异常类的全限定名(2)result:用于指定处理异常后跳转到哪一个逻辑视图该标签可以放在两个位置,一个是作为的子标签,一个是作为
- 谈谈你对Struts的理解
不羁朔风
框架
struts2是一个按照MVC模式设计的一个web层的框架,其实它就相当于一个大的servlet.但是它和servlet是有区别的.servlet默认在第一次访问的时候创建,只创建一次,是单实例对象.struts2的action是多实例对象,每次访问的时候都会创建action对象struts.xml配置文件中的package标签的namespace属性值和action标签里面的name属性值构成访
- Struts 2 数据验证的两种方式——手动验证和xml验证
周大侠_2409
1.手动验证——通过编写action进行验证建立表单login_1.jspname:age:struts.xml编写/index.jsp/success.jspsrc下建立actions包,在里面编写data.Action.javaaddFieldError()方法执行后到/index.jsp,跳转到index对应的页面。若action中有多个方法validate()验证对所有方法都有效若想只对某
- struts2 s:file标签使用及文件上传例子
XXX美琳
Javajava-文件上传与显示
struts.xml配置文件image/bmp,image/png,image/gif,image/jpeg,image/jpg,application/msword,text/plain2000000000/taguser/result_fileTag.jsp/taguser/fileTag.jspUploadAction.java上传处理类publicclassUploadActionexte
- Struts.xml 配置文件说明
趋势大仙
javaj2eestrutsxmljava
包的名称,可自定义,可以配置多个包2.namespace->命名空间,不同模块可以指定不同的空间,必须以"/"开头3.extends->继承,值是直接或间接的继承struts-default,它也是一个xml文件-->/index.html======================================================================1.解决乱码问题//
- sturts.xml配置文件的可视化 视图
凯凯_
1.提供struts.xml配置文件的可视化的视图*去struts2的开发包的lib目录下找到struts2-config-browser-plugin-2.3.15.3.jar,导入到咱们的工程中就可以了。*输入固定的地址(注意:工程名称需要改变):*http://localhost/day26_struts1/config-browser/index.action
- Dispatcher initialization failed解决办法
黑土墨
J2EEinitializationactionfileexceptionlogin
严重:DispatcherinitializationfailedUnabletoloadconfiguration.-action-file:/D:/Program%20Files/apache-tomcat-7.0.8/webapps/login/WEB-INF/classes/struts.xml:5:51atcom.opensymphony.xwork2.config.Configurat
- 通俗易懂之SpringMVC&Struts2前端拦截器详解
Rapper_cl
直接进入主题吧!一,配置Struts2的拦截器分两步走1配置对应的拦截器类:2在配置文件Struts.xml中进行配置拦截器同时在Strust2中配置拦截器类有三种方法1实现Interceptor接口2继承AbstractInterceptor3通过继承MethodFilterInterceptor类区别:是否支持方法过滤性:使用第1,2种其实都差不多,都会拦截Action中所有的方法,但是第3种
- Struts2之拦截器
我愿成为你头顶的云
Struts2框架strutsservletjava
Struts2之拦截器1、Struts2体系架构1.1、执行流程1.2、核心接口和类1.3、流程简图2、Struts2拦截器2.1、使用拦截器的目的2.2、拦截器的简介2.3、拦截器的工作原理2.4、拦截器的使用2.4.1、创建自定义拦截器2.4.2、struts.xml中定义和配置拦截器2.4.3、Struts2默认拦截器2.4.4、拦截器栈2.5、例子1、Struts2体系架构以下图示:1.1
- Struts2之注解
我愿成为你头顶的云
Struts2框架strutsjavaservlet
Struts2之注解1、引入依赖2、注解结构3、注解的使用1、引入依赖Struts2中可以使用注解来代表struts.xml中的某些配置,可以简化配置。要使用注解,必须引入额外的依赖,如下:org.apache.strutsstruts2-convention-plugin2.5.222、注解结构引入依赖后,可以看struts2-convention-plugin的jar包,anotation包如
- 【Struts2】一_idea快速搭建struts2框架
朱尔斯Jules
Struts2框架SSHstruts2javaintellij-idea
文章目录什么是SSH框架?Struts2框架1、struts2的环境搭建`1.1创建web项目(maven),导入struts2核心jar包``1.2配置web.xml(过滤器),是struts2的入口,先进入``1.3创建核心配置文件struts.xml`2、创建项目▶创建HelloAction.java:▶配置web.xml文件▶创建一个hello.jsp页面▶测试▶总结:什么是SSH框架?S
- Struts2基本架构
我愿成为你头顶的云
Struts2框架struts架构servlet
Struts2基本架构1、Struts2执行流程2、web.xml配置3、Action控制器3.1、核心控制器3.2、业务控制器4、Result配置5、struts.xml核心配置5.1、constant元素5.2、package元素5.3、配置文件加载顺序1、Struts2执行流程如下例子:执行流程如下:浏览器将请求发送到服务器。服务器接收请求,根据web.xml中的配置,找到struts2的核
- SpringMVC随笔——认识拦截器
J-Jian
SpringMVCspringmvcinterceptor拦截器MVC新手
SpringMVC随笔——认识interceptor1.拦截器简单介绍1.1SpringMVC拦截器概述SpringMVC的拦截器类似于Struts2的拦截器(一般配置在struts.xml文件中,用来动态拦截Action调用的对象),又不同于Servlet的过滤器(一般配置在web.xml文件中,可以用来拦截任何的请求)。SpringMVC拦截器用于对Action请求进行预处理与后处理。1.2S
- javaweb三大框架知识点总结
wl1411956542
springstruts2hibernatejavaweb框架struts2springhibernate
一、Struts2的总结1、Struts2的工作流程,从请求说起(1)客户端浏览器发出HTTP请求。(2)根据web.xml配置,该请求被FilterDispatcher接收。(3)根据struts.xml配置,找到需要调用的Action类和方法,经过一系列的拦截器(Interceptor)执行后,程序执行到action中的指定的方法,并且从前台接收的参数通过IoC方式,将值注入给Aciton。(
- struts2中struts.xml配置文件详解
小胖5920
转载:https://www.cnblogs.com/wkrbky/p/5889328.htmlstruts2中struts.xml配置文件详解struts.xml的常用配置按Ctrl+C复制代码按Ctrl+C复制代码/error.jsp/talk.jsphttp://www.sina.com一个Action内包含多个请求处理方法的处理Struts1提供了DispatchAction,从而允许一个
- struts2中struts.xml配置文件详解
奔跑的图腾
struts基本配置****/error.jsp/talk.jsp[http://www.sina.com](http://www.sina.com/)实例struts.xml配置-->****admin-struts-config.xml/admin/commCharts/commLineCharts.jsp/admin/commCharts/commMSLineCharts.jsp/admin
- struts2|struts2框架如何使用?
洗黑
struts2框架使用方法有两种如下。一、使用配置文件struts.xml步骤1.配置文件struts.xml需要放在项目src目录下,并进行相关配置,如:struts.xml文件步骤2.框架最基本的13个依赖包导入到/WBEB-INF/lib中struts2框架基础依赖包步骤3.配置文件web.xml的配置web.xml文件二、使用注释注释在action类中使用。使用注释不仅需要导入上面提到到1
- Struts2 框架 配置
有钱了就对着手办冲
struts.xml配置↓/WEB-INF/hello.jsp默认情况下,Filter控制器只处理*.action或没有扩展名的请求,只有符合请求才能进入Action调用流程如果需要修改请求扩展名,可以在struts.xml中追加下面配置web.xml里的配置↓strutsmvcorg.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExec
- 06. struts2中指定struts2处理的请求后缀
c9096743e3b0
概述默认情况下我们都是使用.action后缀访问Action。其实默认后缀是可以通过常量”struts.action.extension“进行修改的。我们可以配置Struts2只处理以.do为后缀的请求路径如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开。如:一些常用的常量常量定义位置常量可以在struts.xml或struts.properties中配置,建议在struts.xm
- struts2命名空间namespace和访问路径的关系
The_Bard
分类:struts2我是在看了别人的博客之后,对namespace和访问路径的关系算是搞明白了,故记录下来供大家参阅和自己以后进行查看。假设我的struts.xml配置文件中一个action配置如下:/index.jsp那么我直接可以通过http://localhost:8089/struts2/testMap.action进行访问,这个的访问过程是这样的,在没有定义namespace的时候,由于
- 08. struts2中为应用指定多个struts配置文件
c9096743e3b0
概述随着应用规模的增加,系统中Action的数量也会大量增加,导致struts.xml配置文件变得非常臃肿为了避免struts.xml文件过于庞大、臃肿,提高Struts.xml文件的可读性,我们可以将一个struts.xml配置文件分解成多个配置文件然后再struts.xml文件中包含其他配置文件操作通过元素指定多个配置文件一个模块使用一个配置文件通过这种方式,可以将struts2的Action
- 四、Struts程序详解
肖sir_嘉立老师
从上一节课的第一个Struts程序的执行过程可知:Struts的中心控制器接受所有来自客户端的请求,并根据系统的配置(struts.xml)路由HTTP请求到其它Action对象。在这些Action对象中会完成所有的业务操作,比如用户登录验证等。处理完毕后,由再由Struts的ControllerServlet根据配置转向到适当的JSP页面,将处理结果显示给用户。因此,这过程中有两个节点是非常重要
- 使用Struts2框架准备工作
ErrorException
1.导入相关jar包Struts2配置核心过滤器使用Struts2需要在lib下的web.xml中配置核心过滤器代码如下:struts2org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilterstruts2/*配置src下struts.xml标签是为了将Action配置封装起来,一个标签下可以配置多个action标签
- 深入浅出Java Annotation(元注解和自定义注解)
Josh_Persistence
Java Annotation元注解自定义注解
一、基本概述
Annontation是Java5开始引入的新特征。中文名称一般叫注解。它提供了一种安全的类似注释的机制,用来将任何的信息或元数据(metadata)与程序元素(类、方法、成员变量等)进行关联。
更通俗的意思是为程序的元素(类、方法、成员变量)加上更直观更明了的说明,这些说明信息是与程序的业务逻辑无关,并且是供指定的工具或
- mysql优化特定类型的查询
annan211
java工作mysql
本节所介绍的查询优化的技巧都是和特定版本相关的,所以对于未来mysql的版本未必适用。
1 优化count查询
对于count这个函数的网上的大部分资料都是错误的或者是理解的都是一知半解的。在做优化之前我们先来看看
真正的count()函数的作用到底是什么。
count()是一个特殊的函数,有两种非常不同的作用,他可以统计某个列值的数量,也可以统计行数。
在统
- MAC下安装多版本JDK和切换几种方式
棋子chessman
jdk
环境:
MAC AIR,OS X 10.10,64位
历史:
过去 Mac 上的 Java 都是由 Apple 自己提供,只支持到 Java 6,并且OS X 10.7 开始系统并不自带(而是可选安装)(原自带的是1.6)。
后来 Apple 加入 OpenJDK 继续支持 Java 6,而 Java 7 将由 Oracle 负责提供。
在终端中输入jav
- javaScript (1)
Array_06
JavaScriptjava浏览器
JavaScript
1、运算符
运算符就是完成操作的一系列符号,它有七类: 赋值运算符(=,+=,-=,*=,/=,%=,<<=,>>=,|=,&=)、算术运算符(+,-,*,/,++,--,%)、比较运算符(>,<,<=,>=,==,===,!=,!==)、逻辑运算符(||,&&,!)、条件运算(?:)、位
- 国内顶级代码分享网站
袁潇含
javajdkoracle.netPHP
现在国内很多开源网站感觉都是为了利益而做的
当然利益是肯定的,否则谁也不会免费的去做网站
&
- Elasticsearch、MongoDB和Hadoop比较
随意而生
mongodbhadoop搜索引擎
IT界在过去几年中出现了一个有趣的现象。很多新的技术出现并立即拥抱了“大数据”。稍微老一点的技术也会将大数据添进自己的特性,避免落大部队太远,我们看到了不同技术之间的边际的模糊化。假如你有诸如Elasticsearch或者Solr这样的搜索引擎,它们存储着JSON文档,MongoDB存着JSON文档,或者一堆JSON文档存放在一个Hadoop集群的HDFS中。你可以使用这三种配
- mac os 系统科研软件总结
张亚雄
mac os
1.1 Microsoft Office for Mac 2011
大客户版,自行搜索。
1.2 Latex (MacTex):
系统环境:https://tug.org/mactex/
&nb
- Maven实战(四)生命周期
AdyZhang
maven
1. 三套生命周期 Maven拥有三套相互独立的生命周期,它们分别为clean,default和site。 每个生命周期包含一些阶段,这些阶段是有顺序的,并且后面的阶段依赖于前面的阶段,用户和Maven最直接的交互方式就是调用这些生命周期阶段。 以clean生命周期为例,它包含的阶段有pre-clean, clean 和 post
- Linux下Jenkins迁移
aijuans
Jenkins
1. 将Jenkins程序目录copy过去 源程序在/export/data/tomcatRoot/ofctest-jenkins.jd.com下面 tar -cvzf jenkins.tar.gz ofctest-jenkins.jd.com &
- request.getInputStream()只能获取一次的问题
ayaoxinchao
requestInputstream
问题:在使用HTTP协议实现应用间接口通信时,服务端读取客户端请求过来的数据,会用到request.getInputStream(),第一次读取的时候可以读取到数据,但是接下来的读取操作都读取不到数据
原因: 1. 一个InputStream对象在被读取完成后,将无法被再次读取,始终返回-1; 2. InputStream并没有实现reset方法(可以重
- 数据库SQL优化大总结之 百万级数据库优化方案
BigBird2012
SQL优化
网上关于SQL优化的教程很多,但是比较杂乱。近日有空整理了一下,写出来跟大家分享一下,其中有错误和不足的地方,还请大家纠正补充。
这篇文章我花费了大量的时间查找资料、修改、排版,希望大家阅读之后,感觉好的话推荐给更多的人,让更多的人看到、纠正以及补充。
1.对查询进行优化,要尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。
2.应尽量避免在 where
- jsonObject的使用
bijian1013
javajson
在项目中难免会用java处理json格式的数据,因此封装了一个JSONUtil工具类。
JSONUtil.java
package com.bijian.json.study;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
- [Zookeeper学习笔记之六]Zookeeper源代码分析之Zookeeper.WatchRegistration
bit1129
zookeeper
Zookeeper类是Zookeeper提供给用户访问Zookeeper service的主要API,它包含了如下几个内部类
首先分析它的内部类,从WatchRegistration开始,为指定的znode path注册一个Watcher,
/**
* Register a watcher for a particular p
- 【Scala十三】Scala核心七:部分应用函数
bit1129
scala
何为部分应用函数?
Partially applied function: A function that’s used in an expression and that misses some of its arguments.For instance, if function f has type Int => Int => Int, then f and f(1) are p
- Tomcat Error listenerStart 终极大法
ronin47
tomcat
Tomcat报的错太含糊了,什么错都没报出来,只提示了Error listenerStart。为了调试,我们要获得更详细的日志。可以在WEB-INF/classes目录下新建一个文件叫logging.properties,内容如下
Java代码
handlers = org.apache.juli.FileHandler, java.util.logging.ConsoleHa
- 不用加减符号实现加减法
BrokenDreams
实现
今天有群友发了一个问题,要求不用加减符号(包括负号)来实现加减法。
分析一下,先看最简单的情况,假设1+1,按二进制算的话结果是10,可以看到从右往左的第一位变为0,第二位由于进位变为1。
 
- 读《研磨设计模式》-代码笔记-状态模式-State
bylijinnan
java设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
/*
当一个对象的内在状态改变时允许改变其行为,这个对象看起来像是改变了其类
状态模式主要解决的是当控制一个对象状态的条件表达式过于复杂时的情况
把状态的判断逻辑转移到表示不同状态的一系列类中,可以把复杂的判断逻辑简化
如果在
- CUDA程序block和thread超出硬件允许值时的异常
cherishLC
CUDA
调用CUDA的核函数时指定block 和 thread大小,该大小可以是dim3类型的(三维数组),只用一维时可以是usigned int型的。
以下程序验证了当block或thread大小超出硬件允许值时会产生异常!!!GPU根本不会执行运算!!!
所以验证结果的正确性很重要!!!
在VS中创建CUDA项目会有一个模板,里面有更详细的状态验证。
以下程序在K5000GPU上跑的。
- 诡异的超长时间GC问题定位
chenchao051
jvmcmsGChbaseswap
HBase的GC策略采用PawNew+CMS, 这是大众化的配置,ParNew经常会出现停顿时间特别长的情况,有时候甚至长到令人发指的地步,例如请看如下日志:
2012-10-17T05:54:54.293+0800: 739594.224: [GC 739606.508: [ParNew: 996800K->110720K(996800K), 178.8826900 secs] 3700
- maven环境快速搭建
daizj
安装mavne环境配置
一 下载maven
安装maven之前,要先安装jdk及配置JAVA_HOME环境变量。这个安装和配置java环境不用多说。
maven下载地址:http://maven.apache.org/download.html,目前最新的是这个apache-maven-3.2.5-bin.zip,然后解压在任意位置,最好地址中不要带中文字符,这个做java 的都知道,地址中出现中文会出现很多
- PHP网站安全,避免PHP网站受到攻击的方法
dcj3sjt126com
PHP
对于PHP网站安全主要存在这样几种攻击方式:1、命令注入(Command Injection)2、eval注入(Eval Injection)3、客户端脚本攻击(Script Insertion)4、跨网站脚本攻击(Cross Site Scripting, XSS)5、SQL注入攻击(SQL injection)6、跨网站请求伪造攻击(Cross Site Request Forgerie
- yii中给CGridView设置默认的排序根据时间倒序的方法
dcj3sjt126com
GridView
public function searchWithRelated() {
$criteria = new CDbCriteria;
$criteria->together = true; //without th
- Java集合对象和数组对象的转换
dyy_gusi
java集合
在开发中,我们经常需要将集合对象(List,Set)转换为数组对象,或者将数组对象转换为集合对象。Java提供了相互转换的工具,但是我们使用的时候需要注意,不能乱用滥用。
1、数组对象转换为集合对象
最暴力的方式是new一个集合对象,然后遍历数组,依次将数组中的元素放入到新的集合中,但是这样做显然过
- nginx同一主机部署多个应用
geeksun
nginx
近日有一需求,需要在一台主机上用nginx部署2个php应用,分别是wordpress和wiki,探索了半天,终于部署好了,下面把过程记录下来。
1. 在nginx下创建vhosts目录,用以放置vhost文件。
mkdir vhosts
2. 修改nginx.conf的配置, 在http节点增加下面内容设置,用来包含vhosts里的配置文件
#
- ubuntu添加admin权限的用户账号
hongtoushizi
ubuntuuseradd
ubuntu创建账号的方式通常用到两种:useradd 和adduser . 本人尝试了useradd方法,步骤如下:
1:useradd
使用useradd时,如果后面不加任何参数的话,如:sudo useradd sysadm 创建出来的用户将是默认的三无用户:无home directory ,无密码,无系统shell。
顾应该如下操作:
- 第五章 常用Lua开发库2-JSON库、编码转换、字符串处理
jinnianshilongnian
nginxlua
JSON库
在进行数据传输时JSON格式目前应用广泛,因此从Lua对象与JSON字符串之间相互转换是一个非常常见的功能;目前Lua也有几个JSON库,本人用过cjson、dkjson。其中cjson的语法严格(比如unicode \u0020\u7eaf),要求符合规范否则会解析失败(如\u002),而dkjson相对宽松,当然也可以通过修改cjson的源码来完成
- Spring定时器配置的两种实现方式OpenSymphony Quartz和java Timer详解
yaerfeng1989
timerquartz定时器
原创整理不易,转载请注明出处:Spring定时器配置的两种实现方式OpenSymphony Quartz和java Timer详解
代码下载地址:http://www.zuidaima.com/share/1772648445103104.htm
有两种流行Spring定时器配置:Java的Timer类和OpenSymphony的Quartz。
1.Java Timer定时
首先继承jav
- Linux下df与du两个命令的差别?
pda158
linux
一、df显示文件系统的使用情况,与du比較,就是更全盘化。 最经常使用的就是 df -T,显示文件系统的使用情况并显示文件系统的类型。 举比例如以下: [root@localhost ~]# df -T Filesystem Type &n
- [转]SQLite的工具类 ---- 通过反射把Cursor封装到VO对象
ctfzh
VOandroidsqlite反射Cursor
在写DAO层时,觉得从Cursor里一个一个的取出字段值再装到VO(值对象)里太麻烦了,就写了一个工具类,用到了反射,可以把查询记录的值装到对应的VO里,也可以生成该VO的List。
使用时需要注意:
考虑到Android的性能问题,VO没有使用Setter和Getter,而是直接用public的属性。
表中的字段名需要和VO的属性名一样,要是不一样就得在查询的SQL中
- 该学习笔记用到的Employee表
vipbooks
oraclesql工作
这是我在学习Oracle是用到的Employee表,在该笔记中用到的就是这张表,大家可以用它来学习和练习。
drop table Employee;
-- 员工信息表
create table Employee(
-- 员工编号
EmpNo number(3) primary key,
-- 姓