完数:一个数的所有因子(除本身外)之和等于这个数,称这个数为完数intmain()//{//inti,j,sum;//for(i=1;i<=1000;i++)//寻找1000之内的完数//{//sum=0;//因子之和的初始化//for(j=1;j
C语言的那点事第三篇:数据类型脱口秀
暮雨哀尘
c语言开发语言青少年编程蓝桥杯算法编辑器
咱们就来一场“编程界的脱口秀”,边抖包袱边写代码,让枯燥的语法也“活”起来。一、数据类型(一)基本数据类型1.整型整型就是那些规规矩矩、不带小数的数字,像1、2、3这种。在代码里,我们可以这样定义一个整型变量:intnum=10;这就相当于在数字王国里,我们抓了一个叫“num”的小兵,给它穿上了整型的制服,还让它站到10这个位置上。2.浮点型浮点型就有点“放荡不羁”,它带着小数点,像3.14这种。
C语言进阶复习
Zhe_lianxi
c语言算法开发语言
今天复习了指针相关概念,前几天有个gets警告的问题,今天来解决一下。对此写一个GetStr函数,参数1:需要获取字符串的字符数组参数2:此字符数组的大小对此,这个编译警告的问题就解决了。#includevoidGetStr(char*Str,intlen);//函数声明intmain(void){charstr[128]={0};GetStr(str,sizeof(str));printf("%
音视频开发——FFmpeg 实现MP4转FLV文件 C语言实现
Trump. yang
音视频开发音视频ffmpegc语言
文章目录转换步骤关键代码完整代码转换步骤初始化FFmpeg库打开输入文件找到输入文件的流信息打开输出文件并设置输出格式创建输出文件的流初始化解码器和编码器读取输入文件的帧并写入输出文件释放资源关键代码1初始化FFmpeg库:av_register_all();打开输入文件:if((ret=avformat_open_input(&input_format_ctx,input_filename,NU
华为OD机试2024年E卷-喊7的次数重排[100分]( Java | Python3 | C++ | C语言 | JsNode | Go)实现100%通过率
梅花C
华为OD题库华为od
题目描述喊7是一个传统的聚会游戏,N个人围成一圈,按顺时针从1到N编号。编号为1的人从1开始喊数,下一个人喊的数字为上一个人的数字加1,但是当将要喊出来的数字是7的倍数或者数字本身含有7的话,不能把这个数字直接喊出来,而是要喊"过"。假定玩这个游戏的N个人都没有失误地在正确的时机喊了"过",当喊到数字K时,可以统计每个人喊"过"的次数。现给定一个长度为N的数组,存储了打乱顺序的每个人喊"过"的次数
用c语言写出变色的心形图案
凌龍墨
C语言c语言心形图案变色心形图案
直接上代码啦!#include#include#include#defineI20#defineR340intmain(){inti,j,e;inta;longtime;for(i=1,a=I;i0;j--)printf("");for(e=1;e0;j--)printf("");for(e=1;e0;j--)printf("");for(e=1;e<=2*(sqrt(R*R-i*i)-(R-2*
黑客常备十大编程语言,每一个都不容易学,但每一个又很有用
一秋的编程笔记
Python编程计算机科技数据库sql爬虫python自动化编程语言
文章目录1、C语言2、Python3、SQL4、Javascript5、PHP6、C++编程7、JAVA8、Ruby9、Perl10、BashPython学习资源分享1、Python所有方向的学习路线2、学习软件3、精品书籍4、入门学习视频5、实战案例6、清华编程大佬出品《漫画看学Python》7、Python副业兼职与全职路线一定要注意,您选择的编程将在很大程度上取决于您要定位的系统类型和计划使
程序员必须掌握的消息中间件-RabbitMQ
后端
一、Rabbit概述RabbitMQ是一个开源的消息代理和队列服务器,用来通过普通协议在完全不同的应用中间共享数据,RabbitMQ是使用Erlang语言来编写的,并且RabbitMQ是基于AMQP协议的。特点:开源、性能优秀Erlang语言最初用在交换机的架构模式,这样使得RabbitMQ在Broker之间进行数据交互的性能时非常优秀的。Erlang的优点:Erlang有着和原生Socket一样
C语言 qsort 详解
Communist19
c语言开发语言
qsort1.定义:qsort,基于快速排序(QuickSort)算法的一个库函数,可以将一串整型类型、浮点类型、字符串类型、结构体类型等的数据进行排序。比冒泡排序,选择法排序好用,且速度更快。2.语法:具体语法如下:qsort(arr,sizeof(arr)/sizeof(arr[0]),sizeof(int),cmp)形参1:arr:需排序数组的首个元素的地址(切记不能用arr[0],arr[
【架构-38】如何选择通信协议和数据格式
W Y
架构websocketrestfulxmljsontcp/ip
一、通信协议选择不同的协议适用于不同的应用场景,关键在于数据传输的需求,如:实时性、带宽、可靠性等。下面是几种常见通信协议的适用场景:WebSocket适用场景:实时、双向数据传输、低延迟、持久连接特点:WebSocket协议允许建立一个持久的全双工(双向)连接,数据可以在客户端和服务器之间实时双向传输。它特别适合用于实时系统,如工业仿真软件中的状态更新、机器人路径跟踪、实时数据流、传感器数据和A
java netty长连接_用netty实现长连接
大笨妞
javanetty长连接
示例代码1:https://github.com/howdyli/netty示例代码2:http://my.oschina.net/bv10000/blog/399388iosasyncsocket示例代码:http://www.superqq.com/blog/2015/04/03/ioskai-fa-zhi-asyncsocketshi-yong-jiao-cheng/长连接服务文章:http
嵌入式Linux系统学习记录10
hhdk1
linux学习运维
在C语言中,指针是一个非常重要的概念。指针是一个变量,它存储的是另一个变量的内存地址。理解指针的细节和注意事项对于编写高效、稳定的C语言程序至关重要。以下是C语言中指针的一些细节和注意事项:1.指针的定义和初始化指针是用*来声明的,表示指向某种类型的变量。例如:int*ptr;//定义一个指向整数的指针初始化指针:指针在定义时不初始化时,会指向不确定的地址,可能导致不可预期的行为。可以将其初始化为
netty~ 基于netty实现服务端的长连接
17245
NIO~NettyNetty长连接心跳检测ScheduledFuture消息编码解码
描述socket长连接即服务端不断开客户端channel的连接,客户端需要定时向服务端进行心跳检测,服务端需要将过期未进行心跳检测的socket关闭。服务端关闭过期的channel连接:Netty提供了ScheduledFuture,可以通过ChannelHandlerContext.executor().schedule()创建,支持延时提交,也支持取消任务,为自动关闭提供了一个很好的实现方案。
[练习]简单结构体操作程序
siy2333
练习算法c语言笔记学习
在学习C语言的过程中,我们经常会接触到各种数据结构的操作,其中数列(数组)是最基本也是最常用的一种。今天,我们分析一个简单的C语言程序,以及进行一定程度的改进。程序概述这个程序的主要目的是实现一个简单的数列操作,包括数列的内存分配、删除指定元素以及输出数列的功能。程序的核心是一个名为sequence的结构体,它包含数列的大小和指向数列元素的指针。通过几个函数的配合,程序完成了数列的创建、修改和输出
19. C语言 共用体(Union)详解
涛ing
C语言基础c语言java算法linuxc++visualstudiovscode
本章目录前言1.什么是共用体?共用体与结构体的区别2.定义共用体示例:定义共用体变量3.共用体的内存布局和对齐规则内存大小计算字节对齐内存对齐原则4.访问共用体成员示例:基本访问5.共用体的实际应用场景场景1:节省内存场景2:网络通信数据包解析场景3:判断系统是大端还是小端6.高效使用共用体的技巧总结前言在C语言中,共用体(union)是一种特殊的复合数据类型,与结构体(struct)类似,但具备
5.0在python中是一个整数常量_python学习之路,基础篇-变量和常量
weixin_39553753
python语言基础1、常量和变量1.1、常量常量是内存中用于保存固定值的单元,在程序中常量的值不能发生改变;python并没有命名常量,也就是说不能像C语言那样给常量起一个名字。python常量包括:数字、字符串、布尔值、空值;1.1.1数字python包括:整数、长整数、浮点数、复数,4种类型的数字;1>整数:表示不包含小数点的实数,在32位计算机上,标准整数的取值范围为-231~231-1,
mysql c mysql_real_connect_MYSQL C API : mysql_real_connect()
司徒夜
mysqlc
MYSQL*mysql_real_connect(MYSQL*mysql,constchar*host,constchar*user,constchar*passwd,constchar*db,unsignedintport,constchar*unix_socket,unsignedlongclientflag);//连接到MYSQL数据库服务器在头文件mysql.h中声明//参数的说明请参考百
指针的 运算 | 为什么指针不能 加/乘/除 指针?|NULL有什么用?|void* 能干什么?指针 详解
编程反思录
C语言必知必会指针c语言编程语言
指针的运算详解[C语言必知必会]指针的运算指针加减常量请看下面的程序,猜测一下结果:intmain(){intarr[10]={1,2,3,4,5,6,7,8,9,10};int*a=&arr;printf("a=%p\n",a);printf("a+1=%p\n",a+1);printf("a-1=%p\n",a-1);}运行结果:a=00AFF82Ca+1=00AFF830a-1=00AFF8
【C语言】C语言基础语法速览
monGyrate
C语言c语言开发语言
C语言基础语法目录C语言基础语法速览1.变量类型1.1类型字节数1.1变量输出格式1.2变量输入格式2.分支循环语句2.1if分支语句2.2switch分支语句2.3while循环语句2.4do...while循环语句2.5for循环语句3.数组3.1一维数组3.2二维数组4.结构体4.1结构体类型定义4.2结构体类型初始化5.共用体6.枚举7.其他防止头文件重复包含C语言基础语法速览1.变量类型
PYTHON中字符串(str)类型和比特(bytes)类型转换
齐柏林fly 艇
python
bytes主要是用于二进制的数据处理的数据类型,在网络编程中,由于服务器和浏览器只能识别bytes类型数据。所以就需要进行数据类型转换例如socket编程中的.send()和.recv()就需要用到str类型和bytes类型转换一、str转bytes:第一种:在str类型前加b,即b"str"第二种:在str后加.encode("utf-8"),即str.encode("utf-8"),编码方式默
【懒加载数据 Objective-C语言】
清风清晨
Objective-Cobjective-ccocoaios
一、咱们就开始进行懒加载1.懒加载发现,每一个字典,是不是就是四个键值对组成的:1)answer:String,中国合伙人,2)icon:String,movie_zghhr,3)title:String,创业励志电影,4)options:Array,21items前三个都是String类型,最后是不是Array类型,所以我们要先建一个模型,是不是来表示它这个东西啊,2.我们首先把这个项目,给它起
游戏开发中不容忽视的粘包问题解析
阿贾克斯的黎明
游戏开发网络
在游戏开发的网络编程领域,粘包问题常常困扰着开发者,它可能导致数据解析错误,进而影响游戏的正常运行和玩家体验。今天,咱们就深入探讨一下粘包问题产生的缘由以及应对之策。一、粘包问题的成因(一)发送端因素缓存机制:TCP协议在传输层运作时,自带一套提升效率的缓存策略。当应用层频繁地、多次地调用发送函数,推送一个个零碎的小数据包时,TCP协议层可不是来一个发一个。它会先把这些小数据包一股脑儿收集到自己的
网络编程(3)reactor事件驱动的机制
jinbaotong
网络windows
前言在传统的阻塞io模型中,服务器通常使用一个循环来不断监听端口是否有新的套接字连接。当有新的连接请求到来时,服务器会接受连接,并创建一个线程来处理该连接的后续读写操作。这种模型的问题在于,如果当前的请求没有处理完,后续的请求将被阻塞,直到前一个请求处理完成。这导致了服务器的吞吐量低下,无法处理高并发连接。为了解决阻塞io模型的问题,人们想到了使用多线程模型,即一请求一线程。这种模型在一定程度上提
C语言#include头文件真的是插入代码吗?头文件并不是编译单元?为什么会有头文件循环依赖?如何得到编译器预处理头文件搜索路径?如何得到编译器预处理搜索到的头文件位置?源代码一定需要包含头文件吗?
程序员小迷
小话c语言编程语言编译器c语言c++visualstudiomsvcgccclang头文件
C语言#include头文件真的是插入代码吗?编译器理论和实作既是又不是。从编译器理论理解,#include头文件"相当于"插入了头文件的代码,以供源代码引用(宏定义、函数声明、其他头文件引入等等),这仅仅是理论的效果。利用GCC-E或者MSVC/E或/P选项可以看到"插入"的效果。从编译器实作角度,为了提高效率,编译器在编译源代码的时候并不会将#include头文件直接插入到当前编译的源代码,一
Objective-C语言的语法糖
Quantum&Coder
包罗万象golang开发语言后端
Objective-C语言的语法糖引言语法糖是编程语言设计中的一个重要概念。它指的是一种可以使得代码更易读和易写的语法形式。对于程序员来说,语法糖就像是糖衣,让一些看似复杂的逻辑变得简单明了。在编程语言中,好的语法糖能够提高开发效率,降低代码的复杂度。在这篇文章中,我们将深入探讨Objective-C语言中的语法糖,如何利用这些语法糖来优化我们的代码结构和可读性。一、Objective-C简介1.
深入浅出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,
-- 姓