- wechatDataBackup一键备份微信聊天记录的工具
夏之繁花
电脑
该项目是用Go语言开发的工具,可一键导出PC端微信聊天记录的工具,帮助用户轻松备份、导出、查找重要对话,适用于Windows平台。全类型消息导出支持导出20+种消息类型,包括:工具可预览未下载内容(如预览图),若需完整导出手机迁移记录,可通过微信官方迁移功能同步至电脑后操作。基础内容:文字、图片、视频、语音、文件、链接、原始表情特殊消息:定位、转账、红包、QQ音乐分享、小程序、视频号直播等复杂场景
- no python 3.8 installation was detected_在python 3.8.1安装numpy时出错"Please upgrade your python"_others_酷...
weixin_39938331
nopython3.8installationwasdetected
我安装了pip,python3.8.1shell中运行"importpip",可以识别到,也没有错误消息,然后我要在终端中安装numpy,运行以下行:pipinstallnumpy得到了:DEPRECATION:Python2.7reachedtheendofitslifeonJanuary1st,2020.pleaseupgradeyourPythonasPython2.7isnolongerm
- no python 3.8 installation was_python 随笔 -- 关于安装 jupyter notebook 时碰到的问题 2020-10-07...
weixin_39760368
nopython3.8installationwas
一。安装jupyter挺早之前我就已经安装好了python解释器,为3.7版本在安装好jupyter之后,运行cmd输入:jupyternotebook路径命令之后,会提示jupyter不是内部命令第一个想到的就是没有配置环境变量,于是去百度搜索怎么配置,根据配置好之后,运行命令,依然还是提示不是内部命令然后去看我python是安装在d盘中的,于是环境变量改成自己安装d盘的路径,运行命令之后还是提
- [ACTF2020 新生赛]Include WriteUp(超级详细)
lunan0320
CTFWebphp安全漏洞
[ACTF2020新生赛]Include欢迎大家访问我的GitHub博客https://lunan0320.github.io/打开靶机发现一个超链接,点击之后出现一段话“Canyoufindouttheflag?”查看源码注入,无果仔细看url,发现有flag.php根据题目提示,该题应该是文件包含漏洞,因此可以判断出此题是PHP伪协议题目,构造payload如下?file=
- [ACTF2020 新生赛]Upload1
不拿flag不改名
androidctf
1、点开题目链接,页面显示如下,上传test.jpg里面包含一句话木马GIF89a?eval($_REQUEST[1])2、使用bp抓包修改后缀,点击发送3、不关浏览器的代理,在bp中将该包放行4、用蚁剑连接5、在根目录中找到flag
- Centos 安装 Python3.8
jeikerxiao
机器学习centospythonlinux
Centos安装python3.8说明Centos7自带有python,版本是python2.7Linux安装python3,需要先下载源码,然后编译安装编译环境yumupdateyum-yinstallgccyum-yinstallzlib-develbzip2-developenssl-develncurses-develsqlite-develreadline-develtk-develgd
- 使用Python绘制一朵永生花
XI锐真的烦
python开发语言
安装/升级Matplotlib尝试以下命令:pipinstall--upgradematplotlib完整代码importnumpyasnpimportmatplotlib.pyplotaspltplt.rcParams['font.sans-serif']=['SimHei']#解决中文乱码fig=plt.figure(figsize=(8,8))ax=fig.add_subplot(111,p
- ThreadLocal 提供线程局部变量
小鸡脚来咯
java开发语言
ThreadLocal作用相当于建立一个独立的空间,可以把使用频率高的任何类型的数据放到里面,方便调用用来存取数据:set()/get()使用ThreadLocal存储的数据,线程安全ThreadLocal工具类/***ThreadLocal工具类*/@SuppressWarnings("all")publicclassThreadLocalUtil{//提供ThreadLocal对象,priva
- 禁止Chrome的自动升级
代先生.重庆
运维服务器Windowschrome
一、需求分析因为用Chrome+selenium做了网页自动化填写任务,如果GoogleChrome浏览器自动升级,就会导致chromedriver加载失败,自动化任务失效,因此需要禁止Chrome浏览器的自动升级。二、当前环境三、实际配置运行注册表编辑器在HKEY_LOCAL_MACHINE\SOFTWARE\Policies下新增Google项,在Google项下面新增Update项,在Upd
- BeautifulSoup4 使用指南
翟萌耘Ralph
BeautifulSoup4使用指南BeautifulSoup4gitmirrorforBeautifulSoup4.3.2项目地址:https://gitcode.com/gh_mirrors/bea/BeautifulSoup4项目概述BeautifulSoup4是一个广受欢迎的Python库,用于从HTML和XML文件中抽取数据。它通过与多种解析器的兼容性提供了一种直观的方法来导航、搜索和修
- Introduction to Software Development
后端
IntroductiontoSoftwareDevelopmentProject–Implementation&TestingAssignment2Submission:EachgroupshouldassumetheroleofaSoftwareStart-upCompany,andwillsubmitthefollowingtwoitems:•WorkingSoftware:Theindivi
- 如何搭建spark yarn模式的集群
lix的小鱼
spark大数据分布式
搭建SparkonYARN模式的集群需要完成Hadoop和Spark的安装与配置,并确保它们能够协同工作。以下是详细的搭建步骤和代码示例:1系统准备操作系统:推荐使用CentOS或Ubuntu。Java环境:安装JDK1.8或更高版本sudoaptupdatesudoaptinstallopenjdk-8-jdkScala环境(可选,视需求而定):sudoaptinstallscala2安装Had
- BeautifulSoup的详细使用说明
API小爬虫
beautifulsoup
BeautifulSoup是一个非常强大的Python库,用于解析HTML和XML文档。它提供了简单易用的API,可以方便地提取和操作文档中的数据。以下是对BeautifulSoup的详细解释,包括其主要功能和使用方法。一、安装BeautifulSoup首先,确保你已经安装了BeautifulSoup和lxml(一个高效的解析器)。可以通过以下命令安装:bashpipinstallbeautifu
- 深度解析 `FOR UPDATE`:数据库行锁的精准掌控之道
hi星尘
sql数据库
在数据库并发控制的领域中,FORUPDATE是一个强大却常被误解的语句。它如同一位隐秘的“锁匠”,在事务的微观世界里,默默地为数据一致性编织着安全网。本文将从底层原理、应用场景、使用陷阱到性能优化,全方位解析FORUPDATE的奥秘。一、FORUPDATE的本质:行锁的显式声明FORUPDATE是SQL标准中用于显式锁定查询结果集行的语法,属于悲观锁(PessimisticLocking)的一种实
- selenium爬虫丁香医生实时播报
weixin_43139613
python基础笔记
fromseleniumimportwebdriverfromselenium.webdriver.common.byimportByfromselenium.webdriver.supportimportexpected_conditionsasECfromselenium.webdriver.support.waitimportWebDriverWaitimportpandasaspdimpo
- Centos 9 stream更改国内yum源
iangyu
centos
备份原有配置cp-r/etc/yum.repos.d/etc/yum.repos.d.backup快速设置阿里云yum源curl-o/etc/yum.repos.d/CentOS-Base.repohttp://mirrors.aliyun.com/repo/Centos-vault-9.repoyumcleanallyummakecacheyumrepolist备选方案,以及其他扩展源编辑文件直
- 数据库3,
lph1972
数据库
describedtdroptable删表dfdeletefrom删行uswupdatesetwhere更新元素iivinsertintovalues()插入行sfselectfrom选行select*选出所有行(oborderby排序由低到高DESC由高到低orderbyscore,student-id意思是score相同的话就排序student-idlimit3限制传回来的数据个数select
- PostgreSQL 漏洞信息详解
文牧之
postgresqlpostgresql数据库运维
PostgreSQL漏洞信息详解PostgreSQL作为一款开源关系型数据库,其安全漏洞会被社区及时发现和修复。以下是PostgreSQL漏洞相关的重要信息和资源。一、主要漏洞信息来源1.官方安全公告PostgreSQL安全信息页面:https://www.postgresql.org/support/security/安全邮件列表:pgsql-announce@postgresql.org2.第
- [ACTF2020 新生赛]Upload 1
,,,642
web安全
[ACTF2020新生赛]Upload这是一道比较简单的文件上传,我直接一次就做出来了上数据包有返回的路径直接就蚁剑连接即可完结
- d2025422
学也不会
算法&sqllinux运维服务器
目录一、182.查找重复的电子邮箱-力扣(LeetCode)二、183.从不订购的客户-力扣(LeetCode)三、184.部门工资最高的员工-力扣(LeetCode)一、182.查找重复的电子邮箱-力扣(LeetCode)采用分组,把邮件名称相同的放到一组having统计这组的个数,个数大于1则证明这个电子邮件是重复的selectemailas'Email'frompersongroupbyem
- mysql ix锁_mysql锁详解
耄先森吖
mysqlix锁
1.mysql锁知多少我们进行insert,update,delete,select会加锁吗,如果加锁,加锁步骤是什么,加的什么类型的锁?行锁里面LOCK_REC_NOT_GAP,LOCK_GAP,LOCK_ORDINARY(Next-KeyLock),LOCK_INSERT_INTENTION这都是些什么锁。锁是在数据库中是怎么构成的,锁之间兼容与互斥关系表上有无唯一索引,增删改动作加索引步骤有
- 缓存并发更新的挑战
左灯右行的爱情
Redis缓存数据库jvm后端redis
缓存并发更新的挑战1.引言:并发更新的挑战2.并发场景下的常见“坑”最后写入胜出(Last-Write-Wins)脏读(DirtyRead)丢失更新(LostUpdate)不可重复读(Non-repeatableRead)幻读(PhantomRead)写偏斜(WriteSkew)缓存与数据库不一致分布式系统中的时序问题3.为什么选择Redis应对并发挑战?4.核心策略:保证数据一致性策略概览5.解
- 坏块处理 ORA-01578: ORACLE data block corrupted (file # 3, block # 152588)
bestsun999
Oracle_19coracle数据库
帮客户检查环境时,发现sysaux表空间的数据文件有坏块,8月25日发生的,备份保留3个月,直接恢复处理。rman备份log报错如下RMAN-00571:===========================================================RMAN-00569:===============ERRORMESSAGESTACKFOLLOWS==============
- Python 爬虫实战:如何爬取百度指数数据并进行分析
Python爬虫项目
python爬虫百度开发语言数据库seleniumdubbo
一、引言百度指数是百度提供的一种数据服务,反映了用户对某一特定关键词的搜索热度变化。它为营销人员、数据分析师以及其他领域的专业人士提供了重要的参考依据。本文将详细介绍如何使用Python编写爬虫,获取百度指数数据,并展示如何对数据进行存储与分析。二、爬虫基础在进行爬虫之前,我们首先需要了解一些基础知识。本文所涉及的爬虫技术主要使用requests和BeautifulSoup等常见库,但为了应对复杂
- Maximum recursive updates exceeded in component <SidebarItem>
bluejad
vue.js前端javascript
问题:[Vuewarn]:Maximumrecursiveupdatesexceededincomponent.Thismeansyouhaveareactiveeffectthatismutatingitsowndependenciesandthusrecursivelytriggeringitself.Possiblesourcesincludecomponenttemplate,render
- Python爬虫(6)静态页面解析实战:BeautifulSoup与lxml(XPath)高效提取数据指南
一个天蝎座 白勺 程序猿
Python爬虫入门到高阶实战python爬虫beautifulsoup
目录一、背景与核心需求二、HTML解析工具对比与选型2.1BeautifulSoup:易用性之王2.2lxml:高性能解析库2.3选型建议三、BeautifulSoup核心方法详解3.1安装与初始化3.2常用方法实战3.3属性与文本提取技巧四、lxml与XPath语法实战4.1安装与初始化4.2XPath语法精讲五、实战案例:豆瓣图书Top250解析5.1使用Beautiful
- Rollup、Webpack、Esbuild 和 Vite 前端打包工具
三思而后行,慎承诺
架构前端webpacknode.js
Rollup、Webpack、Esbuild和Vite都是前端开发中常用的打包工具,它们各有特点,以下是对它们的详细对比:核心功能Rollup:专注于JavaScript模块打包,擅长将小的JavaScript模块打包成一个或多个文件,尤其适合库的打包。它支持ES6模块,能够高效地处理树形摇撼(TreeShaking),去除未使用的代码,从而减小包的体积。Webpack:功能强大且全面,不仅可以处
- 1025 PAT Ranking
理智的灰太狼
pta英文题算法c++数据结构
1025PATRanking分数25全屏浏览切换布局作者CHEN,Yue单位浙江大学ProgrammingAbilityTest(PAT)isorganizedbytheCollegeofComputerScienceandTechnologyofZhejiangUniversity.Eachtestissupposedtorunsimultaneouslyinseveralplaces,andt
- 麒麟V10 aarch64 qt 安装
enyp80
qt开发语言
在麒麟V10(aarch64架构)中安装Qt,需根据具体需求选择合适的方法。以下是综合多个搜索结果的安装方案及注意事项:一、安装方法1.在线安装默认版本适用于对Qt版本无特殊要求的情况。通过APT包管理器安装系统默认提供的Qt版本(如Qt5.12.12):sudoapt-getupdatesudoapt-getinstallqtcreatorqtbase5-devqt5-default优点:简单快
- Python爬虫----------------爬取美食网菜谱(数据库版)
Mr_simoon
Pythonpython数据库
Python爬虫----------------爬取美食网菜谱(数据库版)importrequestsimportpymysqlfrombs4importBeautifulSoup#---------------------------爬取目标网页-----------defpa():indexs=0headers={'User-Agent':'Mozilla/5.0(WindowsNT10.0;
- 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的表,其有一