- 【网络编程】使用函数汇总总结
只对您心动
知识点汇总网络udpc语言linux网络编程
记录自己学习,如果对你有帮助,可以一起学习进步,太多要用的函数了,记不住根本记不住,基本上是TCP、UDP之间的通信相关的一些函数目录1、htonl、htons:主机字节序和网络字节序的相互转换函数2、ntohl、ntohs:网络字节序转换成主机字节序3、inet_addr:将点分十进制转换成网络字节序4、inet_ntoa:将网络字节序转换成点分十进制5、socket函数:为通信创建一个端点,并
- linux 发送自定义包裹 c 程序
黄鱼脑干细胞
linuxc语言网络
#include#include#include#include#include#include#include#includeintmain(void){ints;intsd;chariface[256]="wlp1s0";charpacket[26];structsockaddrsa;s=socket(PF_PACKET,SOCK_PACKET,htons(ETH_P_ALL));if(s<0
- Linux C/C++ 原始套接字:打造链路层ping实现
程序猿编码
C/C++linuxc语言c++网络安全套接字ping
在C/C++中,我们可以使用socket函数来创建套接字。我们需要指定地址族为AF_PACKET,协议为htons(ETH_P_ALL)来捕获所有传入和传出的数据包。可以使用sendto和recvfrom函数来发送和接收数据包。我们需要构建一个合法的链路层数据包,在数据包的头部添加目标MAC地址和源MAC地址,并指定以太网类型为htons(ETH_P_IP)。然后,可以在发送前设置IP头部和ICM
- day4 网络编程
kdhbdsj8494
网络
#include#defineSER_PORT69#defineSER_IP"192.168.122.96"intdownload(intcfd,structsockaddr_insin){//向服务器发送下载请求charbuf[512]="";//组装请求数据short*p1=(short*)buf;*p1=htons(1);char*p2=buf+2;strcpy(p2,"1_armcli.c
- 网络编程 day1
fj199121
网络服务器linux
TCP基础模型服务器端#include#defineIP"192.168.125.83"intmain(intargc,constchar*argv[]){//创建套接字intsfd=socket(AF_INET,SOCK_STREAM,0);//绑定IP地址和端口号structsockaddr_insin;sin.sin_family=AF_INET;sin.sin_port=htons(888
- 1.16 day3 IO网络编程
谢必安灬
网络
用udp实现tftp下载功能#include#definePORT69#defineIP"192.168.122.24"intxiazai(intsfd,structsockaddr_insin,intfd,socklen_tsocklen){charbuf[516]="";charack[4];short*p1=(short*)buf;*p1=htons(1);char*p2=buf+2;str
- 23111 网络编程 day3
z2606200330
网络
思维导图tip协作服务程序如下:#include#defineSER_PORT69#defineSER_IP"192.168.125.180"intdo_upload(intcfd,structsockaddr_insin){//向服务器发送上传请求charbuf[512]="";//组装请求数据short*p1=(short*)buf;*p1=htons(1);char*p2=buf+2;str
- 2024.1.17 网络编程 作业
Carl余
网络php开发语言
思维导图练习题广播服务器端#includeintmain(intargc,charconst*argv[]){//创建套接字intsfd=socket(AF_INET,SOCK_DGRAM,0);//填充网络信息结构体structsockaddr_incin;cin.sin_family=AF_INET;cin.sin_port=htons(6789);cin.sin_addr.s_addr=in
- Linux学习之网络编程2(socket,简单C/S模型)
_snowstorm_
#Linux网络编程Linuxlinux学习网络Linux网络编程套接字socket
写在前面Linux网络编程我是看视频学的,Linux网络编程,看完这个视频大概网络编程的基础差不多就掌握了。这个系列是我看这个Linux网络编程视频写的笔记总结。网络字节序小端法:pc本地存储,高位存高地址,低位存低地址。大端法:网络存储,高位存低地址,低位存高地址。由此我们看到本地和网络的存储方式不一样,所以每次建立连接都要转换,下面我来介绍一些关于大端法和小端法的转换函数。htonl:本地——
- 【嵌入式-网络编程】vmware中使用UDP广播失败问题
Japathy
网络udp网络协议
问题描述:自己在vmware中搭建了2台虚拟机,虚拟机A向虚拟机A和虚拟机B发送广播信息,接收端在虚拟机A和虚拟机B,这个时候,由于没配置sin.sin_addr.s_addr=htonl(INADDR_ANY);,而是配置的inet_pton(AF_INET,SERV_IP,&sin.sin_addr.s_addr);,导致虚拟机A的广播信号发出去了,但是虚拟机B和虚拟机A完全收不到UDP广播数
- 12-19
limbojy0721
c语言
#includeintdo_download(intcfd,structsockaddr_insin){charbuf[516]="";charfileName[40]="";printf("请输入文件名:");scanf("%s",fileName);getchar();short*p1=(short*)buf;*p1=htons(1);char*p2=buf+2;strcpy(p2,fileN
- linux网络----UDP编程
m0_74131325
网络linuxudp
一、函数接口:1.socket:创建一个用来网络通信的终端节点;参数:type:套接字类型SOCK_STREAM流式套接字TCPSOCK_DGRAM数据报套接字UDPSOCK_RAM原始套接字domain:协议族AF_INETprotocal:默认为02.sendto:发送数据消息3.inet_addr:将字符串ip地址转换为内存的ip地址的类型;4.htons:将本地字节序(小端存储)转换成网络
- (important)关于socket的一些理解
Dominiczz
Linuxtcp/ip
关于socket的一些理解importantimportant服务端bind表示之前,要初始化一个结构体structsockaddr_inaddr;addr.sin_family=AF_INET;addr.sin_port=htons(9999);//大端addr.sin_addr.s_addr=INADDR_ANY;//0.0.0.0然后再调用bind函数,表示服务端程序,允许任何本地IP地址接
- Linux网络编程
TheITSea
Linux系统以及网络编程linux
网络概述略,因为科班都学过的哈哈哈哈哈。网络编程基础概念地址其中networkbyteorder表示网络字节序。网络字节序大小端转换所以由上图可知,我们的数据从主机到网络中应该要进行从小端到大端的转换,从网络发到另一台主机时应该要进行大端到小端的转换:这就要涉及到一组函数调用了。ntohs:大小端转换注意这里又要加新的头文件嗷。来简单测试一下:1#include23intmain(){45unsi
- ur机械臂30003端口socket通信踩坑(double类型数据怎么解析)
ljc_coder
编程语言踩坑记录c++学习开发语言网络socket通信
坑的由来都知道在网络通信时要把网络字节序转化为主机字节序才行,但是c++里的标准库函数ntohl默认是转换32位字节序的数据,也就是说默认是转换float类型的数据;而ur机械臂30003端口发送的是double类型的数据,没法直接用ntohl进行转换。小贴士float是4字节,32位;double是8字节,64位。在网络传输中,数据通常以字节为单位进行编码,这种编码方式被称为网络字节序,它主要用
- c++ libevent demo
苍天饶过谁?
c++开发语言
Server::Server(constchar*ip,intport){//创建事件集合base=event_base_new();structsockaddr_inserver_addr;memset(&server_addr,0,sizeof(server_addr));server_addr.sin_family=AF_INET;server_addr.sin_port=htons(por
- Linux网络编程(TCP Socket编程实现过程)
咖喱年糕
LINUX网络linuxtcp/ip服务器ubuntuc语言运维
一、TCPSocketServer服务器基本流程框架1.创建服务器套接字Socket2.设置服务器地址结构htons、inet_aton和inet_ntoa3.绑定服务器套接字Bind4.监听传入的连接请求Listen5.接受客户端连接请求Accept6.服务器数据的收发Recv、Send7.关闭套接字Close代码实现服务器二、TCPSocketClient客户端基本流程框架1.创建客户端套接字
- c++绑定多网卡 组播通信
Acnidouwo
C++UDPc++网络
多网卡时,通过绑定网卡IP地址的方式实现绑定网卡解决组播收不到数据的问题server.sin_family=AF_INET;server.sin_port=htons(pszRemotePort);///server的监听端口server.sin_addr.s_addr=inet_addr(pszRemoteIP);///server的地址1server1.sin_family=AF_INET;s
- 遥感流通的是 QUIC 协议报文
liulilittle
C#C/C++蓝桥杯职场和发展
仅感知Initial、HandshakeQUIC部分协议,通常感知两者就知道是否在通过QUIC协议载荷流量,然后该阻断的阻断,该警告的警告。C++inlineByteGetBitValueAt(Byteb,Byteoffset,Bytelength){return(Byte)((b>>offset)&~(0xffl){returnfalse;}UInt32Version=ntohl(((UInt3
- 【Linux】如何在本地主机实现简易的一对一服务器(附图解与代码实现)
_才疏学浅_
Linuxlinux网络服务器学习
想要实现服务端与客户端一对一的信息传输,我们需要先了解一些基础的结构体与相关函数目录相关的基础结构体1.structsockaddr2.structsockaddr_in相关的基础函数1.htons、htonl、ntohs、ntohl2.inet_pton、inet_ntop函数3.socket函数4.bind函数5.listen函数6.connect函数7.accept函数8.send函数9.r
- c实现 udp通信
xiaobbinm
udpc语言网络协议
1.创建对象intudp_socket=socket(AF_INET,SOCK_DGRAM,0);AF_INET网络通信协议SOCK_DGRAM传输协议属性默认02.想接收信息就需要绑定地址信息structsockaddr_inserver_addr;server_addr.sin_family=AF_INET;server_addr.sin_port=htons(端口);//自选server_a
- iOS推送获取token
晴朗Nic
if(![deviceTokenisKindOfClass:[NSDataclass]])return;constunsigned*tokenBytes=(constunsigned*)[deviceTokenbytes];NSString*hexToken=[NSStringstringWithFormat:@"%08x%08x%08x%08x%08x%08x%08x%08x",ntohl(to
- ipv6从inet_pton得到网络序
戴宏鹏
structsockaddr_in6sa;charstr[INET6_ADDRSTRLEN];unsignedlongnbuf[sizeof(structin6_addr)];inti=inet_pton(AF_INET6,buf,(void*)&sa.sin6_addr);if(i>0){printf("0x%x%x%x%x\n",htonl(sa.sin6_addr.s6_addr32[0])
- Python Socket模块中的IP转换函数
是归人不是过客
PythonSocket模块中包含一些有用IP转换函数,说明如下:socket.ntohl(x)//类似于C语言的ntohl(x)把32位正整数从网络序转换成主机字节序。socket.ntohs(x)//类似于C语言的ntohs(x)把16位正整数从网络序转换成主机字节序。socket.htonl(x)//类似于C语言的htonl(x)把32位正整数从主机字节序转换成网络序。socket.hton
- PF_PACKET
as3522
PF_PACKET瞅代码的时候,看到一个很奇特的socket,sock=socket(PF_PACKET,SOCK_RAW,htons(0x8888))那什么是PF_PACKET?我在网上翻了一下,找到了一片不错的文章,详细sock_raw(注意一定要在root下使用)原始套接字编程可以接收到本机网卡上的数据帧或者数据包,对于监听网络的流量和分析是很有作用的.一共可以有3种方式创建这种socket
- 【Linux网络编程】
Eiker_3169
Linux网络编程udptcp网络协议网络
文章目录一.Linux的网络模型1.网络模型概述2.Linux网络协议栈包含的网络协议3.Linux网络编程模型4.socket套接字编程模型二.UDP编程1编程准备-字节序、地址转换1.1字节序概述1.2htonl函数1.3htons函数1.4ntohl函数1.5ntohs函数1.6地址转换函数inet_pton、inet_ntop1.6.1inet_pton函数1.6.2inet_ntop函数
- Linux 网络编程
考勤卡啦啦
linux网络运维
套接字(Socket):通过网络实现跨机通信作用:一种文件描述符传输层的文件描述符整个编程中,需要着重注意htonl/htons、ntohl/ntohs、inet_addr等TCP的C/S实现循环服务器模型TCP服务器实现过程1.创建套接字:初始化结构体structsockaddr_in2.给套接字绑定ip地址和端口号:bind函数#include3.将套接字文件描述符,从主动变为被动文件描述符(
- hw0921
码不了一点
服务器
多线程发送方#includeintmain(intargc,constchar*argv[]){//创建流式套接字intcfd=socket(AF_INET,SOCK_STREAM,0);printf("socketsuccess\n");//填充服务器地址structsockaddr_insin;sin.sin_family=AF_INET;sin.sin_port=htons(4444);si
- 【InfiniBand】IBV_WR_RDMA_WRITE_WITH_IMM / IBV_WC_RECV_RDMA_WITH_IMM
一尘之中
网络C语言编程c语言linux网络
IB卡带立即数的写操作IBV_WR_RDMA_WRITE_WITH_IMM,对应的远端(remote)接收操作是IBV_WC_RECV_RDMA_WITH_IMM。例:本端(local)写发送:wr.opcode=IBV_WR_RDMA_WRITE_WITH_IMM;wr.send_flags=IBV_SEND_SIGNALED;wr.imm_data=htonl(len);...ibv_post
- LinuxFTP云盘-文件服务系统
m0_74712453
linux服务器运维
目录1.项目介绍2.项目运行展示3.实现思路服务端:客户端:4.相关调用函数socket():创建一个网络通信端点原型:intsocket(intdomain,inttype,intprotocol);atoi():将字符串转变成整型数据原型:intatoi(constchar*nptr);htons():将16位无符号数从主机字节序转换成网络字节序原型:uint16_thtons(uint16_
- 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的表,其有一