- Java的CopyOnWriteArrayList
xbmchina
简介ArrayList并不是线程安全的,在读线程在读取ArrayList的时候如果有写线程在写数据的时候,基于fast-fail机制,会抛出ConcurrentModificationException异常,也就是说ArrayList并不是一个线程安全的容器。那么并发的情况下,这就有了CopyOnWriteArrayList这个东西。下面主要以下几个方面学习CopyOnWriteArrayList
- Java List Iterator ConcurrentModificationException异常原因
二十六画生的博客
JavaSSMJavaListIteratorConcurrentMod
异常原因packagecom.company;importjava.util.ArrayList;importjava.util.Iterator;importjava.util.List;/***@Authoryouguess*@Date2021/1/712:33*@Version1.0*@Desc*/publicclassMain26{publicstaticvoidmain(String[]
- 【Java从入门到放弃 之 ConcurrentModificationException】
ThetaarSofVenice
#Java从入门到放弃java开发语言
ConcurrentModificationExceptionConcurrentModificationException探索ConcurrentModificationException解决问题总结ConcurrentModificationExceptionConcurrentModificationException是Java中的一种运行时异常,通常发生在使用迭代器遍历集合(如ArrayL
- SynchronizedMap 和 ConcurrentHashMap 的区别
yuren_xia
后端技术java
SynchronizedMap和ConcurrentHashMap的区别1.SynchronizedMap定义:通过Collections.synchronizedMap()包装普通HashMap,实现线程安全。锁机制:使用对象级锁(整个Map加锁)。性能:高并发下性能差(锁竞争激烈)。迭代器:迭代时需手动加锁,否则会抛出ConcurrentModificationException。适用场景:低
- java.util.ConcurrentModificationException
KK_crazy
javapythonwindowsstablediffusion开发语言人工智能
错误之王:Java并发修改异常的终极解决方案在Java编程的世界里,java.util.ConcurrentModificationException(并发修改异常)是一个让人头疼的问题。它通常发生在我们尝试在遍历集合的同时修改集合内容时。这个异常就像是程序中的“错误之王”,一旦出现,就意味着你的程序可能正在遭受并发问题的困扰。今天,我将带你深入探讨这个异常的根源,并提供一个根本性的解决方案。20
- kotlin MutableList synchronized
CicadaMay
Android学习
众所周知,ArrayList一不小心就会报ConcurrentModificationException错误,于是尝试用Collections.synchronizedCollection解决valtabList:MutableList=mutableListOf()tabList.add()…vallist=Collections.synchronizedCollection(this)sync
- Java中并发修改异常如何处理
六七_Shmily
javajavawindowspython
在Java中,ConcurrentModificationException(并发修改异常)是遍历集合时最常见的错误之一。它发生在迭代过程中直接修改集合结构(添加/删除元素)时,与是否多线程无关。以下是详细的处理方案:一、异常触发场景Listlist=newArrayListiterator=list.iterator();while(iterator.hasNext()){Strings=ite
- Java中各种线程安全的 List的使用场景和区别
June561
java
Java并发编程中,提供了多种线程安全的List,每种适用于不同的场景。以下是常见的并发List类及其特点:1.CopyOnWriteArrayList适用场景:读多写少(如缓存、配置更新等)底层原理:写操作时复制整个数组,然后替换旧数组,保证读写不会冲突。优点:读操作无锁,性能高。迭代器不会抛出ConcurrentModificationException,即弱一致性。缺点:写操作昂贵(每次写都
- Java ConcurrentModificationException异常原因和解决方法
刘星石
java
原文出处:海子在前面一篇文章中提到,对Vector、ArrayList在迭代的时候如果同时对其进行修改就会抛出java.util.ConcurrentModificationException异常。下面我们就来讨论以下这个异常出现的原因以及解决办法。以下是本文目录大纲:一.ConcurrentModificationException异常出现的原因二.在单线程环境下的解决办法三.在多线程环境下的解
- 快速失败(fail-fast)和安全失败(fail-safe)的区别
代码的余温
java集合类多线程
在Java中,快速失败(Fail-Fast)和安全失败(Fail-Safe)是集合类(Collection)在迭代过程中处理并发修改的两种不同策略,二者的核心区别在于对并发修改的感知机制与容错性。一、快速失败(Fail-Fast)核心特性:一旦检测到集合在迭代过程中被修改(除通过迭代器自身的方法),立即抛出ConcurrentModificationException,终止程序。
- 如何在多线程环境下避免快速失败异常?
Mr.闻吉安
javawindows开发语言
在多线程环境下,可通过以下几种方式避免快速失败(Fail-Fast)异常:1.使用线程安全的集合类Java提供了多种线程安全的集合类,它们在迭代时不会抛出ConcurrentModificationException。示例:使用CopyOnWriteArrayListjavaimportjava.util.Iterator;importjava.util.List;importjava.util.
- 【Java】已解决java.util.ConcurrentModificationException异常
屿小夏
javapython开发语言
个人简介:某不知名博主,致力于全栈领域的优质博客分享|用最优质的内容带来最舒适的阅读体验!文末获取免费IT学习资料!文末获取更多信息精彩专栏推荐订阅收藏专栏系列直达链接相关介绍书籍分享点我跳转书籍作为获取知识的重要途径,对于IT从业者来说更是不可或缺的资源。不定期更新IT图书,并在评论区抽取随机粉丝,书籍免费包邮到家AI前沿点我跳转探讨人工智能技术领域的最新发展和创新,涵盖机器学习、深度学习、自然
- 【Java】解决Java报错:ConcurrentModificationException
E绵绵
Everythingjava开发语言
文章目录引言1.错误详解2.常见的出错场景2.1遍历过程中修改集合2.2使用`Iterator`进行删除操作3.解决方案3.1使用`Iterator`的`remove`方法3.2使用`CopyOnWriteArrayList`3.3使用`synchronized`块4.预防措施4.1使用线程安全的集合类4.2使用合适的遍历和修改方法4.3单元测试结语引言在Java编程中,ConcurrentMod
- 重学Java基础篇—什么是快速失败(fail-fast)和安全失败(fail-safe)?
Remember_Ray
重学Java系列java
快速失败(fail-fast)和安全失败(fail-safe)是两种不同的迭代器设计策略,主要用于处理集合(如List、Map)在遍历过程中被修改的场景。它们的核心区别在于对并发修改的容忍度和实现机制。1.快速失败(fail-fast)定义快速失败是一种“零容忍”的机制。当集合在遍历过程中被修改(如添加、删除元素),迭代器会立即抛出ConcurrentModificationException,强
- StarRocks关于ConcurrentModificationException 问题的解决
鸿乃江边鸟
大数据StarRocksSQLstarrocks大数据sql
背景本文基于StarRocks3.1.7目前在基于Starrocks做一些数据分析的操作(主要是做一些简单的查询),同事遇到了一些并发的问题:ontent:2024-11-2707:04:34,048WARN(starrocks-mysql-nio-pool-214933|3593819)[StmtExecutor.execute():643]executeException,sqlSELECTd
- 关于将HashMap替换原有Map的key保持value不变报错java.util.ConcurrentModificationException的处理方案
梦岚如雪
轮子库之HashMapjava工具类java开发语言后端HashMap
前言由于苦逼的在公司支持上线,在等待es集群分片完成过程,实在闲的无聊,将之前本地Notion记得一些笔记扔上来一些打发下时间吧( ̄. ̄)需求有个类似下面的数据为Map>>,其中key为资源id,value为List>,{"4757637007194717896":[{"oracleTableSpaceSize":"30000","oracleTableName":"System4","oracl
- Java集合中fail-fast和fail-safe机制详解
橡 皮 人
Java集合java集合的fail机制
在使用集合时候,大家应该都遇到过或听过并发修改异常(ConcurrentModificationException),这其实是Java集合中的一种fail-fast机制,为了避免触发fail-fast机制,Java中还提供了一些采用fail-safe机制设计的集合类,本篇文章就系统的介绍一下这两种机制。一、fail-fast机制1.1什么是fail-fast机制简单的说,这就是系统设计的一种理念,
- 常见Java集合
人才瘾大
java数据结构哈希算法
1.fail-fast和fail-safe机制fail-fast(快速失败)和fail-safe(安全失败)是两种在遍历集合时处理并发修改的策略。1.1.fail-fast机制遍历集合时,如果发现集合被修改(除了通过迭代器自身的remove方法),会立即抛出ConcurrentModificationException异常。这种机制的目的是快速检测到不一致性并报告错误。如,使用ArrayList时
- Java中处理并发修改异常
dreammaker阿甘
JAVAjavapythonwindows
在Java中,当一个或多个线程正在遍历集合对象时,如果同时有线程试图修改该集合(增加、删除元素等),就可能会抛出`ConcurrentModificationException`。这种异常主要发生在使用迭代器(Iterator)遍历集合的过程中。处理这种并发修改异常的策略主要有以下几种:###1.使用并发集合Java的`java.util.concurrent`包提供了一些线程安全的集合,如`Co
- Java基础常见面试题总结-集合(二)
此花本应与她
java
迭代器Iterator是什么?Iterator模式用同一种逻辑来遍历集合。它可以把访问逻辑从不同类型的集合类中抽象出来,不需要了解集合内部实现便可以遍历集合元素,统一使用Iterator提供的接口去遍历。它的特点是更加安全,因为它可以保证,在当前遍历的集合元素被更改的时候,就会抛出ConcurrentModificationException异常。publicinterfaceCollection
- ConcurrentModificationException异常解决办法
李die喋
有关java.util.ConcurrentModificationException最近在写抓包项目,一直困扰我的问题就是安卓多线程的问题。因为抓取到的数据包是大量的,我的想法是拿到一个数据包就开一个socektchannl和服务器进行对接。但是就在想会不会cpu的资源占有率太高出现OOM,果然出现了这样的问题。将线程放到了线程池里面也出现了OOM,真的是让我有点不知所措,感觉自己对多线程这不会
- ConcurrentModificationException异常原因,解决方法,线程安全的单例模式
Rose J
Android开发之路单例模式javajvm
异常简介ConcurrentModificationException(并发修改异常)是基于java集合中的快速失败(fail-fast)机制产生的,在使用迭代器遍历一个集合对象时,如果遍历过程中对集合对象的内容进行了增删改,就会抛出该异常。快速失败机制使得java的集合类不能在多线程下并发修改,也不能在迭代过程中被修改。异常原因示例代码valelements:MutableList=mutabl
- 使用两种多线程模式消费Kafka数据
魏春雨
使用两种多线程模式消费数据KafkaProducer是线程安全的,然而KafkaConsumer却是非线程安全的。KafkaConsumer中定义了一个acquire(方法,用来检测当前是否只有一个线程在操作,若有其他线程正在操作则会抛出Concurrentmodifcationexception异常:java.util.ConcurrentModificationException:KafkaC
- Iterable和Iterator之间的区别以及延伸讨论
曾泽浩
本文会讨论几个问题Iterable和Iterator的区别讨论为什么需要Iterable和Iterator,只保留Iterator行不行迭代器遍历时,抛出ConcurrentModificationException的原因foreach语法糖验证首先看一下Iterable的定义publicinterfaceIterable{/***Returnsaniteratoroverelementsofty
- java集合ArrayList和HashSet的fail-fast与fail-safe以及ConcurrentModificationException
zlpzlpzyd
javajava
在java的集合工具类中,例如对ArrayList或者HashSet进行删除元素后再遍历元素时,会抛出ConcurrentModificationException异常。fail-fastArrayListpublicclassTestList{publicstaticvoidmain(String[]args){ArrayListlist=newArrayListlist=newArrayLis
- java.util.ConcurrentModificationException理解
Alex老夫子
javajavakotlinConcurrentModificationException
java.util.ConcurrentModificationException这个异常想必大家都遇到过,可以通过源码找到根因,容器类,比如ArrayList、HashMap、HashSet,循环方法中可以得知有个modCount发生变化,当同时遍历容器对象,同时增加或者删除元素,就会抛出ConcurrentModificationException,源码如下:@Overridepublicvo
- JUC并发编程-集合不安全情况以及Callable线程创建方式
666-LBJ-666
JUC并发编程多线程并发编程JUC
6.集合不安全1)List不安全//java.util.ConcurrentModificationException并发修改异常!publicclassListTest{publicstaticvoidmain(String[]args){ListarrayList=newArrayList{arrayList.add(UUID.randomUUID().toString().substring
- Iterator迭代器操作集合元素时,不能用集合删除元素
孤独斗士
windows
在使用Iterator迭代器对集合中的元素进行迭代时,如果调用了集合对象的remove()方法删除元素或者调用add()方法添加元素之后,继续使用迭代器遍历元素,会出现异常(java.util.ConcurrentModificationException)。importjava.util.ArrayList;importjava.util.Iterator;importjava.util.fun
- java linkedlist 线程安全_LinkedList线程安全问题
陶晓博
javalinkedlist线程安全
Java中LinkedList是线程不安全的,那么如果在多线程程序中有多个线程访问LinkedList的话会出现什么问题呢?抛出ConcurrentModificationExceptionJDK代码里,ListItr的add(),next(),previous(),remove(),set()方法都会跑出ConcurrentModificationException。finalvoidcheck
- 集合线程安全
MaoSource
java线程线程安全
集合线程安全常用的集合类型如ArrayList,HashMap,HashSet等,在并发环境下修改操作都是线程不安全的,会抛出java.util.ConcurrentModificationException异常,这节主要记录如何在并发环境下安全地修改集合数据。List举个ArrayList线程不安全的例子:publicclassCollectionTest{publicstaticvoidmai
- 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的表,其有一