- 动态代理,JDK 动态代理和 CGlib 动态代理的区别?
蒂法就是我
java开发语言动态代理JDK动态代理CGlib动态代理
程序员面试资料大全|各种技术书籍等资料-1000G一、本质区别维度JDK动态代理CGLib动态代理实现机制基于接口反射基于字节码增强(ASM操作字节码)代理目标必须实现至少一个接口可代理普通类(无需接口)生成物$Proxy0接口代理类TargetClass$$EnhancerByCGLIB子类方法拦截原理InvocationHandler.invoke()MethodInterceptor.int
- Feign请求参数传递问题解决方案
在SpringCloudFeign中,FeignRequestInterceptor需要被注册为Spring的Bean才能生效,但不需要特定的注解标记拦截器本身。以下是详细说明:1.拦截器类本身不需要特殊注解FeignRequestInterceptor类本身是一个普通的Java类,实现RequestInterceptor接口即可,不需要添加特定注解:importfeign.RequestInte
- Spring MVC拦截器配置全攻略
代码的余温
springmvcjava后端
在SpringMVC中配置拦截器主要通过以下两种方式实现,需结合HandlerInterceptor接口的三个核心方法(preHandle、postHandle、afterCompletion)完成功能扩展:一、基于Java配置(推荐)定义拦截器类实现HandlerInterceptor接口或继承HandlerInterceptorAdapter抽象类:publicclassAuthInterce
- Axios 拦截器实现原理深度剖析:构建优雅的请求处理管道
斯~内克
前端前端javascript
在构建现代前端应用时,网络请求处理是关键环节。作为最流行的HTTP客户端库之一,Axios通过其拦截器机制(Interceptors)提供了强大的请求/响应处理能力。本文将深入Axios源码,揭示拦截器背后的精妙设计与实现原理。一、拦截器机制的核心价值在深入源码前,先理解拦截器的核心作用:请求预处理:动态添加认证头、参数序列化响应后处理:统一错误处理、数据格式化行为监控:请求日志、性能跟踪流程控制
- Frida-Native层Hook
Dr. 熊
#AndroidFridajavascript开发语言
文章目录Hook能力Hook有符号函数Hook无符号函数原函数不执行的Hook问题TypeError:cannotreadproperty'add'ofnull报错问题原因解决方案doublehookHook能力Hook有符号函数//Module.getExportByName:搜索so文件中的函数位置Interceptor.attach(Module.getExportByName('libna
- 无感刷新token解决方案
在你的axios封装文件中,你需要两个外部变量来管理状态://标记是否正在刷新token的“锁”letisRefreshing=false;//存储因token失效而挂起的请求的“队列”letrequestQueue=[];请求拦截器(RequestInterceptor)它的任务很简单:在每个请求发出去之前,都带上当前的token。importaxiosfrom'axios';constserv
- 农银一面:Filter、Interceptor、Spring AOP 的执行顺序
IT枫斗者
JAVA基础工作中实际总结编程学习springhivejavaredis后端jvm数据库
农银一面:Filter、Interceptor、SpringAOP的执行顺序引言在我们的日常开发工作中,Filter(过滤器)、Interceptor(拦截器)和AOP(面向切面编程)是非常常用的3种请求处理技术。在不同的应用场景中,使用它们都可以在不影响主业务逻辑的前提下为系统增加额外的功能。面试官去问这个问题的时候,一般是想考察求职者的技术深度和对框架机制的理解。本篇我们从3者的基本概念及使用
- axios 自定义添加请求头 单独添加请求头
好了来看下一题
jsajaxjavascript
axios自定义添加请求头axios封装importVuefrom'vue'importaxiosfrom'axios'axios.defaults.timeout=5000;axios.defaults.baseURL=process.env.VUE_API_ROOT;//请求拦截axios.interceptors.request.use((config)=>{letuserToken=win
- Mybatis实现多租户
@ConfigurationpublicclassMyBatisPlusConfig{/***分页插件**@return*/@BeanpublicPaginationInterceptorpaginationInterceptor(){PaginationInterceptorpaginationInterceptor=newPaginationInterceptor();//创建SQL解析器集合
- Android OkHttp控制链:深入理解网络请求的流程管理
追随远方
Android开发androidokhttp网络
OkHttp作为Android和Java平台上广泛使用的HTTP客户端,其核心设计之一就是"控制链"(Chain)机制。本文将深入探讨OkHttp控制链的工作原理、实现细节以及如何利用这一机制进行高级定制。一、什么是OkHttp控制链OkHttp控制链是一种责任链模式的实现,它将HTTP请求的处理过程分解为多个有序的步骤,每个步骤由一个"拦截器"(Interceptor)负责。当发起一个网络请求时
- 在 Spring Boot 中使用 WebFilter:实现请求拦截、日志记录、跨域处理等通用逻辑!
一个有女朋友的程序员
SpringBootspringbootservlet
前言在开发Web应用时,我们经常需要对所有请求进行统一处理,例如:记录请求日志实现跨域(CORS)接口权限控制请求参数预处理防止XSS攻击这些功能如果都写在每个Controller或Service里,不仅代码冗余,还难以维护。幸运的是,SpringBoot提供了两种强大的拦截机制:Filter(过滤器)Interceptor(拦截器)本文将重点讲解如何在SpringBoot中使用WebFilter
- mybatis 打印完整的执行sql
samopig
mysqlmysqllogging
packagecom.mips.sql;importorg.apache.ibatis.executor.parameter.ParameterHandler;importorg.apache.ibatis.plugin.Interceptor;importorg.apache.ibatis.plugin.Intercepts;importorg.apache.ibatis.plugin.Invo
- spring boot拦截器HandlerInterceptor详解
吸引力的觉悟
SpringBootspringboot拦截器Handle
上一篇对过滤器的定义做了说明,也比较简单。过滤器属于Servlet范畴的API,与Spring没什么关系。Web开发中,我们除了使用Filter来过滤请web求外,还可以使用Spring提供的HandlerInterceptor(拦截器)。HandlerInterceptor的功能跟过滤器类似,但是提供更精细的的控制能力:在request被响应之前、request被响应之后、视图渲染之前以及req
- Spring拦截器——HandlerInterCeptor
2513835321
springjavahibernate
毕设过程中碰到Spring拦截器,不知其原理,特此在此查询总结一、简介SpringWebMVC的处理器拦截器,类似于servlet开发中的过滤器Filter,用于处理器进行预处理和后处理。二、HandlerInterrceptor拦截器常用的用途(1)日志记录:记录请求信息的日志。以便进行信息监控,信息统计,计算PV等(2)权限检查:如登录检测,进入处理器检测是否登录,如果没有直接返回到登录页面。
- SpringBoot拦截器详解-HandlerInterceptor
海螺炒面
springboot后端java
文章目录拦截器实现注册拦截器小结拦截器实现实现拦截器需要实现HandlerInterceptor接口或者继承HandlerInterceptorAdapter类此处两种方式均写一下importjavax.servlet.http.HttpServletRequest;importjavax.servlet.http.HttpServletResponse;importjavax.servlet.h
- spring boot中interceptor拦截器未生效的解决
志在崂山
springbootjavaservlet
开始用的springboot版本为1.5.6代码如下:@ConfigurationpublicclassWebConfigextendsWebMvcConfigurerAdapter{@AutowiredprivateTimeInterceptortimeInterceptor;@OverridepublicvoidaddInterceptors(InterceptorRegistryregist
- Mybatis-plus动态数据权限解决方案
奋斗的老史
java开发经验mybatis
com.baomidoumybatis-plus-boot-starter3.5.3.1packagecom.itwenqiang.dynamicsql;importcom.baomidou.mybatisplus.annotation.DbType;importcom.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;im
- 过滤器和拦截器有什么区别?
玄魄灵归
Javajavaspringmvc过滤器拦截器
过滤器和拦截器有什么区别?在Web开发中,过滤器(Filter)和拦截器(Interceptor)是两个常用的组件,它们都能对请求进行预处理和后处理。但很多开发者对两者的区别存在疑惑,本文将从技术实现、应用场景、核心特性等多个维度深入解析二者的差异。一、定义与核心作用对比1.过滤器(Filter)技术定位:Servlet规范的原生组件,基于JavaEE标准,所有支持Servlet的容器(如Tomc
- SpringBoot 性能太差?试试这几招!
程序员闪充宝
javaspring多线程springbootredis
大家好,我是宝哥!目录异步执行增加内嵌Tomcat的最大连接数使用@ComponentScan()默认Tomcat容器改为Undertow使用BufferedWriter进行缓冲Deferred方式实现异步调用异步调用可以使用AsyncHandlerInterceptor进行拦截异步执行实现方式二种:使用异步注解@aysnc、启动类:添加@EnableAsync注解JDK8本身有一个非常好用的Fu
- Filter和Interceptor详解(一文了解执行阶段及其流程)
liubo666_
FilterInterceptorSpringGatewaySpringSecurityjava
Filter和Interceptor的区别Filter(过滤器)和Interceptor(拦截器)都是用于在请求处理前后插入额外逻辑的组件,下面依次介绍,并额外介绍SpringGateway的过滤器(GlobalFilter/GatewayFilter)和SpringSecurity的过滤器(SecurityFilter)过滤器(Filter)基本概念所属规范:JavaServlet规范(java
- Springboot + Mybatis 实现sql打印
长而不宰
springbootmybatissql
参照这个视频:https://www.bilibili.com/video/BV1MS411N7mn/?vd_source=90ebeef3261cec486646b6583e9f45f5实现mybatis对外暴露的接口Interceptor使用@Intercepts接口,这里的写法参照mybatis-plus中的拦截器写法@Intercepts({@Signature(type=Executor
- TenantLineInnerInterceptor源码解读
changelzj
MyBatis-Plusjava
目录一、引言二、主要源码解读2.1beforeQuery/beforePrepare2.2processSelect2.3processInsert2.3.1最常见的新增SQL语句2.3.2批量新增数据的SQL语句2.3.3ONDUPLICATEKEYUPDATE的SQL2.3.4INSERTSELECT的SQL2.3.5SELECTINTO的结构2.4processUpdate2.5proces
- mybatis-plus多租户实现
stephen.ly
多租户javaspringboot
获取header中租户id编写拦截器@ComponentpublicclassHeadersInterceptorimplementsHandlerInterceptor{@OverridepublicbooleanpreHandle(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler)throwsExceptio
- 电商数仓项目(八) Flume(3) 生产者和消费者配置
涛2021
数据仓库:Hadoop+Hiveflumekafka
目录一、生产数据写到kafka二、消费kafka数据写到hdfs本节讲解Flume生产者和消费者配置。源码下载一、生产数据写到kafka将上节生成的flume-interceptor-1.0.0.jar文件上传到$FLUME_HOME/lib目录下在$FLUME_HOME/conf目录中创建file-flume-kafka.conf文件,文件目录:/u01/gmall/data/in/log-da
- mybtais plus使用拦截器打印完整SQL语句
weixin_42502300
sql数据库
1、pom文件com.baomidoumybatis-plus-boot-starter3.5.5com.github.yulichangmybatis-plus-join-boot-starter1.5.32、拦截器importcom.baomidou.mybatisplus.extension.plugins.inner.InnerInterceptor;importlombok.extern
- Spring Boot—拦截器及其应用场景
碎碎念...
SpringBoot框架总结javaspringboot
文章目录0.前言1.拦截器的核心接口与原理拦截器的执行流程`HandlerInterceptor`接口的三个核心方法2.示例:创建一个简单的拦截器3.示例:拦截器的注册与配置4.多拦截器链式调用5.拦截器与过滤器的区别6.总结0.前言在现代的SpringBoot应用开发中,拦截器(Interceptor)是一个非常重要的机制。它位于客户端请求到达Controller之前和响应返回之后的中间环节,可
- 【vue】封装接口,全局字典,表格表头及使用
咔咔库奇
VUEvue.jsjavascript前端
一、封装接口(API请求)1.创建axios实例//src/utils/request.jsimportaxiosfrom'axios'constservice=axios.create({baseURL:process.env.VUE_APP_BASE_API,timeout:10000})//请求拦截器service.interceptors.request.use(config=>{conf
- springboot,全版日志,request日志,请求日志
R-sz
springboot后端java
packagecom.pantech.wecom.interceptor;importcom.alibaba.cloud.commons.io.IOUtils;importlombok.extern.slf4j.Slf4j;importorg.springframework.web.servlet.HandlerInterceptor;importjavax.annotation.Resource
- Mybatis-Plus 集成 YashanDB 时分页功能怎么配置?
makabalala
mybatisandroid
问题背景在使用Mybatis-Plus开发项目并接入YashanDB时,若未正确配置分页插件或数据库方言,可能导致分页功能失效或报错。推荐配置方式使用Oracle模式配置(推荐):pagehelper:helperDialect:oracleMybatisPlusInterceptorinterceptor=newMybatisPlusInterceptor();interceptor.addIn
- OkHttp 连接池 详解
weixin_42754390
Androidjavascript开发语言ecmascript
OkHttp框架采用的是Socket连接,底层涉及到Http协议的封装和解封,TLS/SSL安全协议的封装等;连接池主要涉及到几大类:ConnectionPool,RealConnection,StreamAllocation,ConnectionInterceptor;1.ConnectionPool类:该类是OkHttp的连接池,连接池可以有效地提高连接的使用效率;主要涉及到添加,获取,删除连
- jQuery 跨域访问的三种方式 No 'Access-Control-Allow-Origin' header is present on the reque
qiaolevip
每天进步一点点学习永无止境跨域众观千象
XMLHttpRequest cannot load http://v.xxx.com. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:63342' is therefore not allowed access. test.html:1
- mysql 分区查询优化
annan211
java分区优化mysql
分区查询优化
引入分区可以给查询带来一定的优势,但同时也会引入一些bug.
分区最大的优点就是优化器可以根据分区函数来过滤掉一些分区,通过分区过滤可以让查询扫描更少的数据。
所以,对于访问分区表来说,很重要的一点是要在where 条件中带入分区,让优化器过滤掉无需访问的分区。
可以通过查看explain执行计划,是否携带 partitions
- MYSQL存储过程中使用游标
chicony
Mysql存储过程
DELIMITER $$
DROP PROCEDURE IF EXISTS getUserInfo $$
CREATE PROCEDURE getUserInfo(in date_day datetime)-- -- 实例-- 存储过程名为:getUserInfo-- 参数为:date_day日期格式:2008-03-08-- BEGINdecla
- mysql 和 sqlite 区别
Array_06
sqlite
转载:
http://www.cnblogs.com/ygm900/p/3460663.html
mysql 和 sqlite 区别
SQLITE是单机数据库。功能简约,小型化,追求最大磁盘效率
MYSQL是完善的服务器数据库。功能全面,综合化,追求最大并发效率
MYSQL、Sybase、Oracle等这些都是试用于服务器数据量大功能多需要安装,例如网站访问量比较大的。而sq
- pinyin4j使用
oloz
pinyin4j
首先需要pinyin4j的jar包支持;jar包已上传至附件内
方法一:把汉字转换为拼音;例如:编程转换后则为biancheng
/**
* 将汉字转换为全拼
* @param src 你的需要转换的汉字
* @param isUPPERCASE 是否转换为大写的拼音; true:转换为大写;fal
- 微博发送私信
随意而生
微博
在前面文章中说了如和获取登陆时候所需要的cookie,现在只要拿到最后登陆所需要的cookie,然后抓包分析一下微博私信发送界面
http://weibo.com/message/history?uid=****&name=****
可以发现其发送提交的Post请求和其中的数据,
让后用程序模拟发送POST请求中的数据,带着cookie发送到私信的接入口,就可以实现发私信的功能了。
- jsp
香水浓
jsp
JSP初始化
容器载入JSP文件后,它会在为请求提供任何服务前调用jspInit()方法。如果您需要执行自定义的JSP初始化任务,复写jspInit()方法就行了
JSP执行
这一阶段描述了JSP生命周期中一切与请求相关的交互行为,直到被销毁。
当JSP网页完成初始化后
- 在 Windows 上安装 SVN Subversion 服务端
AdyZhang
SVN
在 Windows 上安装 SVN Subversion 服务端2009-09-16高宏伟哈尔滨市道里区通达街291号
最佳阅读效果请访问原地址:http://blog.donews.com/dukejoe/archive/2009/09/16/1560917.aspx
现在的Subversion已经足够稳定,而且已经进入了它的黄金时段。我们看到大量的项目都在使
- android开发中如何使用 alertDialog从listView中删除数据?
aijuans
android
我现在使用listView展示了很多的配置信息,我现在想在点击其中一条的时候填出 alertDialog,点击确认后就删除该条数据,( ArrayAdapter ,ArrayList,listView 全部删除),我知道在 下面的onItemLongClick 方法中 参数 arg2 是选中的序号,但是我不知道如何继续处理下去 1 2 3
- jdk-6u26-linux-x64.bin 安装
baalwolf
linux
1.上传安装文件(jdk-6u26-linux-x64.bin)
2.修改权限
[root@localhost ~]# ls -l /usr/local/jdk-6u26-linux-x64.bin
3.执行安装文件
[root@localhost ~]# cd /usr/local
[root@localhost local]# ./jdk-6u26-linux-x64.bin&nbs
- MongoDB经典面试题集锦
BigBird2012
mongodb
1.什么是NoSQL数据库?NoSQL和RDBMS有什么区别?在哪些情况下使用和不使用NoSQL数据库?
NoSQL是非关系型数据库,NoSQL = Not Only SQL。
关系型数据库采用的结构化的数据,NoSQL采用的是键值对的方式存储数据。
在处理非结构化/半结构化的大数据时;在水平方向上进行扩展时;随时应对动态增加的数据项时可以优先考虑使用NoSQL数据库。
在考虑数据库的成熟
- JavaScript异步编程Promise模式的6个特性
bijian1013
JavaScriptPromise
Promise是一个非常有价值的构造器,能够帮助你避免使用镶套匿名方法,而使用更具有可读性的方式组装异步代码。这里我们将介绍6个最简单的特性。
在我们开始正式介绍之前,我们想看看Javascript Promise的样子:
var p = new Promise(function(r
- [Zookeeper学习笔记之八]Zookeeper源代码分析之Zookeeper.ZKWatchManager
bit1129
zookeeper
ClientWatchManager接口
//接口的唯一方法materialize用于确定那些Watcher需要被通知
//确定Watcher需要三方面的因素1.事件状态 2.事件类型 3.znode的path
public interface ClientWatchManager {
/**
* Return a set of watchers that should
- 【Scala十五】Scala核心九:隐式转换之二
bit1129
scala
隐式转换存在的必要性,
在Java Swing中,按钮点击事件的处理,转换为Scala的的写法如下:
val button = new JButton
button.addActionListener(
new ActionListener {
def actionPerformed(event: ActionEvent) {
- Android JSON数据的解析与封装小Demo
ronin47
转自:http://www.open-open.com/lib/view/open1420529336406.html
package com.example.jsondemo;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
impor
- [设计]字体创意设计方法谈
brotherlamp
UIui自学ui视频ui教程ui资料
从古至今,文字在我们的生活中是必不可少的事物,我们不能想象没有文字的世界将会是怎样。在平面设计中,UI设计师在文字上所花的心思和功夫最多,因为文字能直观地表达UI设计师所的意念。在文字上的创造设计,直接反映出平面作品的主题。
如设计一幅戴尔笔记本电脑的广告海报,假设海报上没有出现“戴尔”两个文字,即使放上所有戴尔笔记本电脑的图片都不能让人们得知这些电脑是什么品牌。只要写上“戴尔笔
- 单调队列-用一个长度为k的窗在整数数列上移动,求窗里面所包含的数的最大值
bylijinnan
java算法面试题
import java.util.LinkedList;
/*
单调队列 滑动窗口
单调队列是这样的一个队列:队列里面的元素是有序的,是递增或者递减
题目:给定一个长度为N的整数数列a(i),i=0,1,...,N-1和窗长度k.
要求:f(i) = max{a(i-k+1),a(i-k+2),..., a(i)},i = 0,1,...,N-1
问题的另一种描述就
- struts2处理一个form多个submit
chiangfai
struts2
web应用中,为完成不同工作,一个jsp的form标签可能有多个submit。如下代码:
<s:form action="submit" method="post" namespace="/my">
<s:textfield name="msg" label="叙述:">
- shell查找上个月,陷阱及野路子
chenchao051
shell
date -d "-1 month" +%F
以上这段代码,假如在2012/10/31执行,结果并不会出现你预计的9月份,而是会出现八月份,原因是10月份有31天,9月份30天,所以-1 month在10月份看来要减去31天,所以直接到了8月31日这天,这不靠谱。
野路子解决:假设当天日期大于15号
- mysql导出数据中文乱码问题
daizj
mysql中文乱码导数据
解决mysql导入导出数据乱码问题方法:
1、进入mysql,通过如下命令查看数据库编码方式:
mysql> show variables like 'character_set_%';
+--------------------------+----------------------------------------+
| Variable_name&nbs
- SAE部署Smarty出现:Uncaught exception 'SmartyException' with message 'unable to write
dcj3sjt126com
PHPsmartysae
对于SAE出现的问题:Uncaught exception 'SmartyException' with message 'unable to write file...。
官方给出了详细的FAQ:http://sae.sina.com.cn/?m=faqs&catId=11#show_213
解决方案为:
01
$path
- 《教父》系列台词
dcj3sjt126com
Your love is also your weak point.
你的所爱同时也是你的弱点。
If anything in this life is certain, if history has taught us anything, it is
that you can kill anyone.
不顾家的人永远不可能成为一个真正的男人。 &
- mongodb安装与使用
dyy_gusi
mongo
一.MongoDB安装和启动,widndows和linux基本相同
1.下载数据库,
linux:mongodb-linux-x86_64-ubuntu1404-3.0.3.tgz
2.解压文件,并且放置到合适的位置
tar -vxf mongodb-linux-x86_64-ubun
- Git排除目录
geeksun
git
在Git的版本控制中,可能有些文件是不需要加入控制的,那我们在提交代码时就需要忽略这些文件,下面讲讲应该怎么给Git配置一些忽略规则。
有三种方法可以忽略掉这些文件,这三种方法都能达到目的,只不过适用情景不一样。
1. 针对单一工程排除文件
这种方式会让这个工程的所有修改者在克隆代码的同时,也能克隆到过滤规则,而不用自己再写一份,这就能保证所有修改者应用的都是同一
- Ubuntu 创建开机自启动脚本的方法
hongtoushizi
ubuntu
转载自: http://rongjih.blog.163.com/blog/static/33574461201111504843245/
Ubuntu 创建开机自启动脚本的步骤如下:
1) 将你的启动脚本复制到 /etc/init.d目录下 以下假设你的脚本文件名为 test。
2) 设置脚本文件的权限 $ sudo chmod 755
- 第八章 流量复制/AB测试/协程
jinnianshilongnian
nginxluacoroutine
流量复制
在实际开发中经常涉及到项目的升级,而该升级不能简单的上线就完事了,需要验证该升级是否兼容老的上线,因此可能需要并行运行两个项目一段时间进行数据比对和校验,待没问题后再进行上线。这其实就需要进行流量复制,把流量复制到其他服务器上,一种方式是使用如tcpcopy引流;另外我们还可以使用nginx的HttpLuaModule模块中的ngx.location.capture_multi进行并发
- 电商系统商品表设计
lkl
DROP TABLE IF EXISTS `category`; -- 类目表
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `category` (
`id` int(11) NOT NUL
- 修改phpMyAdmin导入SQL文件的大小限制
pda158
sqlmysql
用phpMyAdmin导入mysql数据库时,我的10M的
数据库不能导入,提示mysql数据库最大只能导入2M。
phpMyAdmin数据库导入出错: You probably tried to upload too large file. Please refer to documentation for ways to workaround this limit.
- Tomcat性能调优方案
Sobfist
apachejvmtomcat应用服务器
一、操作系统调优
对于操作系统优化来说,是尽可能的增大可使用的内存容量、提高CPU的频率,保证文件系统的读写速率等。经过压力测试验证,在并发连接很多的情况下,CPU的处理能力越强,系统运行速度越快。。
【适用场景】 任何项目。
二、Java虚拟机调优
应该选择SUN的JVM,在满足项目需要的前提下,尽量选用版本较高的JVM,一般来说高版本产品在速度和效率上比低版本会有改进。
J
- SQLServer学习笔记
vipbooks
数据结构xml
1、create database school 创建数据库school
2、drop database school 删除数据库school
3、use school 连接到school数据库,使其成为当前数据库
4、create table class(classID int primary key identity not null)
创建一个名为class的表,其有一