- Golang Channel
PandaSkr
golang
Channel解析1.Channel源码分析1.1Channel数据结构typehchanstruct{qcountuint//channel的元素数量dataqsizuint//channel循环队列长度bufunsafe.Pointer//指向循环队列的指针elemsizeuint16//元素大小closeduint32//channel是否关闭0-未关闭elemtype*_type//元素类
- iOS——atomic、nonatomic、assign、_unsafe_unretain
糸师凛
ioscocoamacos
atomic和nonatomic在iOS开发中,当你定义一个属性时,编译器会自动为你生成一个带下划线的成员变量(实例变量)以及对应的getter和setter方法。如果你使用atomic修饰这个属性,那么编译器在生成setter和getter方法时,会在这些方法的内部实现中加入加锁操作。但是加锁只能保证getter和setter方法内部的线程安全,并不能保证对该属性的所有操作都是线程安全的。具体的
- php操作mysql防止sql注入(合集)
get200
mysqlmysql注入
本文将从sql注入风险说起,并且比较addslashes、mysql_escape_string、mysql_real_escape_string、mysqli和pdo的预处理的区别。当一个变量从表单传入到php,需要查询mysql的话,需要进行处理。举例:$unsafe_variable=$_POST[‘user_input’];mysqli_query(“INSERTINTOtable(col
- [edge浏览器]网站使用的是 HSTS。网络错误和攻击通常是暂时的,因此该页面以后可能会恢复正常。
冰淇淋烤布蕾
edge
问题访问网站是这样的解决办法在当前页面直接输入thisisunsafe(不是地址栏,直接就打字就可以)然后就神奇地进去了原因了解主要看这两个博客[问题解决][edge]你现在无法访问XXX.com,因为网站使用的是HSTS。网络错误和攻击通常是暂时的,因此该页面以后可能会恢复正常。_因为网站使用的是hsts。网络错误和攻击通常是暂时的,因此该页面以后可能会恢复正-CSDN博客(2022年12月)解
- 切片slice的几个要注意的坑
追云的风C
1.切片的底层实现:在runtime包下的slice.go中我们可以看到切片的底层实现。切片其实是一个结构体,对应有三个字段。我要注意的是第一个字段,它是一个数组指针,指向对应的数组存储空间。typeslicestruct{arrayunsafe.Pointer//数组指针lenint//切片长度capint//切片容量}直接声明的切片不能使用下标赋值。因为此时并未分配给切片存储空间。但可以使用a
- Channel(一)chan数据结构
LitC
chan数据结构typehchanstruct{qcountuint//totaldatainthequeuedataqsizuint//sizeofthecircularqueuebufunsafe.Pointer//pointstoanarrayofdataqsizelements环形队列指针elemsizeuint16//队列元素大小closeduint32//标识关闭状态elemtype*
- Mojo实现unsafe pointer详解及接口说明
启航学途
MojomojoMojopointerMojoanypointermojopointer详解mojopointer接口mojo入门mojo基础教程
anypointerImplementagenericunsafepointertype.YoucanimporttheseAPIsfromthememorypackage.Forexample:frommemory.anypointerimportAnyPointerAnyPointerThisisapointertypethatcanpointtoanygenericvaluethatismo
- axios Refused to set unsafe header has been blocked by CORS policy
未金涛
Pythonvue前端爬虫
前言事情是这样的,我准备复制一个资源下载类的网站。第一步肯定是爬取目标网站的资源了。我在用python写爬虫的时候,当我提取完网页中的基础数据之后。就发现,目标网站后面大部分的数据都是通过有规律的api返回的json数据源。这个时候作为一个白飘党,我就在想能不能直接白嫖对面的api,直接拿来用呢?然后,在前端遇到了些问题,我感觉以我现在的技术水准无法解决。前端axios请求示例axios({met
- Go语言:nil切片和空切片
哒嘎哇
GOgolang开发语言后端
参考引用:packagemainimport("fmt""reflect""unsafe")funcmain(){vars1[]ints2:=make([]int,0)s4:=make([]int,0)fmt.Printf("s1pointer:%+v,s2pointer:%+v,s4pointer:%+v,\n",*(*reflect.SliceHeader)(unsafe.Pointer(&s
- go 切片(创建、nil切片、空切片、切片拷贝)
leo_jk
go切片go
一、什么是切片1.切片就是一个“动态”数组,即切片的长度是可以伸缩的。其数据结构是一个结构体,包含三个字段,指向数组的指针、长度、容量。typeslicestruct{arrayunsafe.Pointer//一个指向数组的指针lenintcapint}2.切片的指针指向某个数组,所以它是引用类型。3.代码验证切片是引用类型packagemainimport"fmt"//传入切片funcchang
- 文件绕过-Unsafe Fileuoload
Ryongao
网络安全
文件上传基础什么是文件上传将客户端数据以文件形式封装·通过网络协议发送到服务器端,在服务器端解析数据,最终在服务端硬盘上作为真实的文件保存。通常一个文件以HTTP协议进行上传时,将以POST请求发送至Web服务器,Web服务器收到请求并同意后,用户与Web服务器将建立连接,并传输数据文件上传产生漏洞的原因文件上传漏洞危害上传文件的时候,如果服务器端脚本语言未对上传的文件进行严格的验证和过滤,就容易
- 无锁类原理详解与使用,无锁算法详解,全是干货
纵然间
Javajava开发语言
目录编辑一、无锁类的原理详解1.1CAS1.2CPU指令二、无锁类的使用2.1AtomicInteger2.1.1概述2.1.2主要接口2.1.3主要接口实现2.2Unsafe2.2.1概述2.2.3主要接口2.3AtomicReference2.3.1概述2.3.2主要接口2.4AtomicStampedReference2.4.1概述2.4.2主要接口2.5AtomicIntegerArray
- Netty源码系列 之 ChannelPipeline & IO处理回顾 源码
etcEriksen
Netty源码java后端netty
目录ChannelPipeline【包含AbstractUnsafe.write的源码流程,比之前更加深化了,必看】ChannelPipeline概念回顾ChannelPipeline的创建Inbound(输入Handler)所对应的事件传播Outbound(输出Handler)所对应的事件传播【包含AbstractUnsafe.write的源码流程,比之前更加深化了,必看】ChannelPipe
- 从零开始学howtoheap:fastbins的double-free攻击实操3
网络安全我来了
逆向二进制Re网络安全安全系统安全安全架构
how2heap是由shellphish团队制作的堆利用教程,介绍了多种堆利用技术,后续系列实验我们就通过这个教程来学习。环境可参见从零开始配置pwn环境:优化pwn虚拟机配置支持libc等指令-CSDN博客1.fastbins的double-free攻击这个程序展示了怎样利用free改写全局指针chunk0_ptr达到任意内存写的目的,即unsafeunlink。2.unsafeunlink程序
- 查看内存工具
Abner_XuanYuan
importFoundationpublicenumMemAlign:Int{caseone=1,two=2,four=4,eight=8}privatelet_EMPTY_PTR=UnsafeRawPointer(bitPattern:0x1)!///辅助查看内存的小工具类publicstructMems{privatestaticfunc_memStr(_ptr:UnsafeRawPointe
- python调用golang的函数
风中孤狐
golanggolangpython开发语言
python调用golangpython调用golang脚本,中间需要通过cgo进行golang部分需要先导入cgo和一些标准库import("fmt""quote/node_exporter""unsafe")/*#cgoCFLAGS:#include#include*/import"C"//需要紧挨着暴露一些golang函数注意://和export必须要紧挨着如果需要传参的话,需要用c的类型字
- Rust初体验感想
勤奋的程哥
rust
最近花了半个月的时间入门了Rust编程语言,简要的写一下对这门语言的感想。对于困扰于C/C++编程中经常出现的解引用空指针、解引用野指针、内存多次释放这些常见的bug的我来说,Rust的出现完美的解决了以上所有这些问题。首先,Rust中不存在空指针,如果要表示一个值是否存在,只能用Option枚举表示。但unsafe块是个例外。实际上对unsafe块中的指针操作就近乎C中对指针的操作了,因此暂时不
- error C4996: 'scanf': This function or variable may be unsafe.Visual Studio系列编译器使用scanf函数报错
Wang__Peter
IDEvisualstudio
在使用VisualStudio系列编译器使用scanf函数是,是否需到下面这句话呢?errorC4996:‘scanf’:Thisfunctionorvariablemaybeunsafe.Considerusingscanf_sinstead.Todisabledeprecation,use_CRT_SECURE_NO_WARNINGS.Seeonlinehelpfordetails.刚开始使用
- Cesium+MapboxGL+VectorTile -2
seelingzheng
Cesiummvt矢量瓦片
这里主要讲述Cesium通过MapboxGL加载不同服务的情况,分别包括服务部署和发布,以及使用。Cesium+MapboxGL+VectorTile-1调用postgis服务环境搭建,本文基于mac系统来编写brewinstallpostgreserror:Commandfailedwithexit128:git执行brew-v,可以看到fatal:unsaferepository。。。设置sa
- go 内存二进制数据操作
docker真的爽爆了
golang开发语言后端
go内存二进制数据操作go内存二进制数据直接操作以数字类型为例int(linux/macos为int32,windows为int64).如果不清楚可以使用unsafe.Sizeof函数来查看(函数出来的值*8就是int位数)若不使用内存二进制数据操作,你需要在每次获取数字内容时调用binary.BigEndian/LittleEndian的方法来计算出数字大小。而具体是大端还是小端计算由系统决定.
- Netty源码 之 bind绑定流程
etcEriksen
Netty源码java
1.Netty框架总览Netty是一个基于NIO异步通信框架Netty框架是由许多组件,优化的数据结构所构建成。正是通过灵活的组件构建,优化后的数据结构,进而才能保证Netty框架面对高并发场景具有一定的能力1.1Netty相关组件Netty重要的组件有:Channel,EventLoop,Unsafe,ChannelPipeline,Bootstrap,ServerBootstrap等Chann
- 线程安全之可见性(Volatile)和原子性(Atomic)
飞跃南墙的晓M
JAVA基础线程可见性线程原子性
线程安全之可见性(Volatile)和原子性线程之可见性可见性原理分析线程间操作的定义同步的规则定义Happens-before先行发生原则Final修饰符线程可见性总结线程安全之原子性原子操作存在的问题及分析原因示例代码:存在的问题解决办法1)借助sun.misc.Unsafe类:2)使用CAS(Compareandswap)线程之可见性可见性原理分析可见性问题:让一个线程对共享变量的修改,能够
- zabbix配置监控脚本
怡雪~
zabbixzabbix
zabbix配置监控脚本1.修改agent配置文件[root@chang~]#vim/etc/zabbix/zabbix_agentd.conf333行原#UnsafeUserParameters=0修改成UnsafeUserParameters=12.创建脚本与脚本存放目录[root@chang~]#mkdir/etc/zabbix/zabbix_scripts[root@changzabbix
- electron安装
Legendary
1.、安装npm如果你的机器上还没有Node.js®和npm,请安装它们。2、全局安装electronnpminstall-gelectron-prebuiltmac系统需要在管理员权限下安装哟,输好密码就可以开始等他安装了。sudonpminstall-gelectron-prebuilt上面可能会安装不成功,现改为:sudonpminstall-gelectron--unsafe-perm=t
- linux中npm run build 报错处理
浅浅_2d5a
npmrunbuild1、报错internal/modules/cjs/loader.js:883解决cnpminstall@vue/cli-service--unsafe-perm2、ERRORin./node_modules/
[email protected]@css-loader...解决npmrebuildnode-sass3
- golang sudog是什么?
动态一时爽,重构火葬场
langconcurrentgolang开发语言
sudog代表在等待队列中的goroutine,比如channel发送接受。由于goroutine和同步对象的关系是多对多,因此需要sudog映射typesudogstruct{//指向的goroutineg*g//指向前后sudog的指针next*sudogprev*sudog//指向数据elemunsafe.Pointer//dataelement(maypointtostack)//Thef
- 上传文件el-upload
开水没有冬天
上传
文章目录上传报错Blob详解Refusedtogetunsafeheader"content-disposition"xxxx手动触发,用el-upload组件的this.$refs['fileUpload'].submit()触发http-request函数:onUpload(file){console.log('onUpload-custom:file:',file)letformData=n
- C#多线程实践——锁和线程安全
diaobeizhou2045
c#
锁实现互斥的访问,用于确保在同一时刻只有一个线程可以进入特殊的代码片段,考虑下面的类:classThreadUnsafe{staticintval1,val2;staticvoidGo(){if(val2!=0)Console.WriteLine(val1/val2);val2=0;}}这不是线程安全的:如果Go方法被两个线程同时调用,可能会得到在某个线程中除数为零的错误,因为val2可能被一个线
- 导出文件获取文件名时遇到的错误:Refused to get unsafe header
壮语
问题:通过XMLHttpRequest做导出csv文件时候拿不到文件名并报错Refusedtogetunsafeheader"Content-Disposition"解决:跨域问题导致的,需要后端在头信息Access-Control-Expose-Headers中加入Content-Disposition字段参考跨域资源共享CORS详解
- 死磕 java魔法类之Unsafe解析
编程小世界
问题(1)Unsafe是什么?(2)Unsafe只有CAS的功能吗?(3)Unsafe为什么是不安全的?(4)怎么使用Unsafe?简介本章是java并发包专题的第一章,但是第一篇写的却不是java并发包中类,而是java中的魔法类sun.misc.Unsafe。Unsafe为我们提供了访问底层的机制,这种机制仅供java核心类库使用,而不应该被普通用户使用。但是,为了更好地了解java的生态体系
- 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的表,其有一