- 数据结构与算法-链表(练习二)
LoveXming
链表数据结构算法
数据结构与算法-链表刷题练习删除链表的倒数第n个元素刷题练习删除链表的倒数第n个元素输入链表为:5->4->3->2->1,3输出链表为:5->4->2->1#include#include#include#includeusingnamespacestd;structNode{intm_nValue;Node*m_pNext;Node(intnValue,Node*pNext=nullptr):
- 洛谷题单1-P5705 【深基2.例7】数字反转-python-流程图重构
独好紫罗兰
LuoGu-pythonpython算法开发语言
题目描述输入一个不小于100100100且小于100010001000,同时包括小数点后一位的一个浮点数,例如123.4123.4123.4,要求把这个数字翻转过来,变成4.3214.3214.321并输出。输入格式一行一个浮点数输出格式一行一个浮点数输入输出样例输入123.4输出4.321方式-字符串反转代码classSolution:@staticmethoddefoi_input():"""
- leetcode简单题4 N.14 最长公共前缀 rust描述
独好紫罗兰
leetcode算法rust
//["flower","flow","flight"]"fl"//["dog","racecar","car"]""//纵向扫描同一个索引扫描其他所有字符pubfnlongest_common_prefix(strs:Vec)->String{ifstrs.is_empty(){//如果向量不包含任何元素,则返回truereturnString::new();//返回空字符串}letmutpre
- CF每日5题Day2(1400)
啊我不会诶
codeforce练习c++算法数据结构
根据通过人数二分法练题,每日打卡。1-1427B一组字符串nnn个Wxxx组连续W得分2n−x2n-x2n−x得分尽量高就要增大nnn减小xxx所以要把W尽量连起来老是wa2202行错误想不出来哪里没想到决定先放一放structidx{intl,r;};voidsolve(){//1427Bintn,k;cin>>n>>k;strings;cin>>s;vectorva;intw=0,wcnt=0
- CF每日5题Day4(1400)
啊我不会诶
codeforce练习算法数据结构
好困,感觉很累,今天想赶紧写完题早睡。睡眠不足感觉做题都慢了。1-1761C构造voidsolve(){intn;cin>>n;vector>a(n+1);forr(i,1,n){//保证每个集合不同a[i].push_back(i);}forr(i,1,n){strings;cin>>s;forr(j,1,n){if(s[j-1]=='1')a[j].push_back(i);//i是j的子集j
- C++ 仿函数详解:让对象像函数一样调用
禁默
C++c++开发语言
前言在C++中,仿函数(Functor)是指重载了operator()的类或结构体的对象,它们的行为类似于普通函数,因此可以像函数一样被调用。仿函数在STL算法、回调机制、函数适配器等场景中有着广泛的应用。本文将深入探讨仿函数的概念、优点、使用方式,并结合具体示例进行详细解析。1.为什么需要仿函数?在C++中,我们可以用普通函数或std::function(C++11引入)来定义可调用对象,但仿函
- JVM 如何打破双亲委派模型?
冰糖心书房
JVMjvm
虽然双亲委派模型是Java类加载机制的推荐实现方式,但在某些情况下,为了实现特定的功能,可能需要打破双亲委派模型。以下是一些常见的打破双亲委派模型的方法和场景:1.重写loadClass方法(不推荐):原理:java.lang.ClassLoader的loadClass方法实现了双亲委派模型的逻辑。默认情况下,loadClass方法会先检查类是否已经被加载过,如果没有,则委托给父类加载器加载。如果
- LearnOpenGL(七):编写自定义的Shader类
米芝鱼
LearnOpenGLc++开发语言算法Shader图形渲染游戏
在前面的文章中我们已经了解了Shader在OpenGL中的使用流程,但是这样每一次都要链接与创建实在是很不方便。而在c++中,类对象能很好的帮助我们实现重复的功能模块,我们需要自定义一个Shader类,如下:#ifndefSHADERTOOL_H#defineSHADERTOOL_H#include#include#include#include#includeclassShader{public
- js对象练习
晚枫~
js练习
1.做一个倒计时效果。functioncountDown(time){varnowTime=+newDate();//返回的是当前时间总的毫秒数varinputTime=+newDate(time);//返回的是用户输入时间总的毫秒数vartimes=(inputTime=nowTime)/1000;//time是剩余时间总的秒数vard=parseInt(times/60/60/24);//天d
- Flutter_学习记录_AppBar中取消leading的占位展示
一人前行
flutter学习flutter
将leading设置为null将automaticallyImplyLeading设置为false看看automaticallyImplyLeading的说明:Controlswhetherweshouldtrytoimplytheleadingwidgetifnull.Iftrueand[AppBar.leading]isnull,automaticallytrytodeducewhatthel
- Linux Shell脚本自动化编程实战【1.3 bash中调用python expect】
wallacegen
bashlinux自动化
在bash中调用python#!/usr/bin/bashping-c1114.114.114.114>/dev/null&&echo"success"/usr/bin/python<<-EOFprint("helloworld")EOFecho"hellobash"1.将python代码交给python解释器来执行2.EOF只是一个标记,换成<
- 封装了一个支持多个分区的iOS自适应动态宽度layout
刘小哈哈哈
ioscocoamacos
支持多分区的动态自适应宽度layout,完善了之前只支持一个分区的布局,这里直接上代码,可以用来在商品sku,搜索记录,编辑tab等场景的使用,灵活性强,支持代理配置////LBNumberCenterEditTabLayout.m////Createdbyliuboon26.3.25.//#importNS_ASSUME_NONNULL_BEGIN@protocolLBNumberCenterE
- redis 模块
阿慕路泽
#Python模块
Redis是一个开源的使用ANSIC语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。它通常被称为数据结构服务器,因为值(value)可以是字符串(String),哈希(Map),列表(list),集合(sets)和有序集合(sortedsets)等类型。Redis与其他key-value缓存产品有以下三个特点:Redis支持数据的
- Python基础知识第二天:从格式化到流程控制
程序员
Python基础知识第二天:从格式化到流程控制大家好!今天我们来梳理Python的一些重要基础知识,包括格式化输出、输入函数、运算符以及流程控制语句。1.格式化输出Python提供了多种格式化输出的方式:#%d,%f,%s格式化name="Python"age=30print("我叫%s,今年%d岁"%(name,age))#F-string方式(推荐)print(f"我叫{name},今年{ag
- This is deprecated. The new driver class is com.mysql.cj.jdbc.Driver.的解决办法及原因
C4程序员
Java菜鸟之路mysql数据库java
1.问题描述Thisisdeprecated.Thenewdriverclassis`com.mysql.cj.jdbc.Driver'.2.原因Spring2.2以后的版本是默认支持MySQL8的,所以当你的MySQL版本是8及以上就需要修改你的加载驱动3.解决办法同时注意时区东八区serverTimezone=GMT%2B84.补充privatestaticStringurl="jdbc:my
- 线程池 JDK1.5 ExecutorService threadPool = Executors.newFixedThreadPool(3)
飞腾创客
java
packagecn.itcast.heima2;importjava.util.concurrent.ExecutorService;importjava.util.concurrent.Executors;importjava.util.concurrent.TimeUnit;publicclassThreadPoolTest{/***@paramargs*/publicstaticvoidma
- 16、Python继承与多态机制深度解析
wolf犭良
pythonpython开发语言
Python继承与多态机制深度解析文章导言本文深入探讨Python面向对象编程中继承与多态的核心机制,涵盖从基础语法到高级用法的完整知识体系。通过理论解析、代码实战和典型场景案例,助您掌握继承体系的构建方法、MRO算法的底层逻辑、多态特性的工程实践,以及抽象基类在接口设计中的妙用。文末提供10个阶梯式练习题及完整答案代码。一、继承机制深度剖析1.1单继承体系classAnimal:def__ini
- Spring Boot添加全局异常处理器捕捉异常 跳转登录页面
Java&Develop
Java开发springboot状态模式后端
SpringBoot添加全局异常处理器捕捉异常跳转登录页面二、后端异常处理添加全局异常处理器在SpringBoot中创建GlobalExceptionHandler,捕获所有异常并返回统一JSON格式:1.这里和下面的2选一个就可以这里可以改成跳转登录@RestControllerAdvicepublicclassGlobalExceptionHandler{@ExceptionHandler(E
- [C笔记] 常见函数和关键字
无码龄
c语言笔记开发语言
printf---printfunction---打印函数/打印功能scanf---scanfunction---扫描函数/输入函数extern---external---声明一个变量,告诉编译器这个变量在别的文件中定义了,先声明后使用const---comstant---常量,修饰变量,表示该变量是常量,不能被修改enum---enumeration---枚举,定义枚举类型,枚举类型是一种用户自
- C语言:学生信息管理系统
阿威昂
c语言c语言链表数据结构
采用链表来连接各同学的信息,进行打印,删除,插入增加,修改,查找。typedefstructstudent{charname[20];intage;intstunum;intscore;}student;//建立一个关于学生信息的结构体typedefstruct_Node{studentstu;struct_Node*pnext;}Node;//建立一个链表。Node*g_phead=NULL;/
- 【力扣hot100题】(014)轮转数组
梭七y
leetcode算法数据结构
感谢力扣,好久没遇到过这么简单的题目了,并且比较考验基础(vector的各种删除拼接操作)。先储存起后k个元素,然后从第nums.size()-k处一一后移,最后将储存元素替换原来的前k个元素即可。classSolution{public:voidrotate(vector&nums,intk){k=k%nums.size();vectorrecord(nums.end()-k,nums.end(
- 【力扣hot100题】(013)合并区间
梭七y
leetcode算法职场和发展
一开始并不相信直接sort会更快,于是一直在试map……我错了…………方法就是直接sort之后循环,每次循环找后面的元素直到不能合并(直到后面元素的前一个小于目前元素的后一个),然后目前元素瞬移为遍历到的那个元素。总之想了挺久的。classSolution{public:vector>merge(vector>&intervals){sort(intervals.begin(),intervals
- django filters
Ang-l
#引入fromdjango_filters.rest_frameworkimportDjangoFilterBackendfromrest_frameworkimportfilters,enerics#使用class继承generics.ListAPIView#例1:classTest(generics.ListAPIView):'''由于内部封装了get方法可以不重写如:'''serialize
- Java Optional介绍,创建,map 与 flatMap 的妙用
茶本无香
javaOptionalflatMap
1.Optional简介为什么需要Optional?在Java8之前,处理null是一个常见的痛点。代码中充斥着if(obj!=null)的判断,不仅冗长,还容易遗漏,导致NullPointerException。Optional的设计目标:明确表示“值可能不存在”的语义,替代隐式的null。强制开发者显式处理空值,减少NPE风险。支持链式函数式操作,提升代码可读性。2.创建Optional对象O
- Django自定义FilterSet
蓝绿色~菠菜
Djangodjangopython后端
需求:根据时间范围过滤数据实现:1、定义FilterSetimportrest_framework_filtersasfiltersclassTimeFilterSet:"""根据时间范围过滤"""filter_map={'Date':django_filters.DateFilter,'Time':django_filters.DateTimeFilter,'DateTime':django_f
- 【力扣hot100题】(010)滑动窗口最大值
梭七y
leetcode算法职场和发展
在前几天笔试的时候做到了差不多的,就是将元素按顺序排,每次加入新元素时检查前面元素是否大于(小于)该元素,这样就能保持队列的单调性,然后要取最大(最小)值的时候直接取最前面的元素就行。(这道题每次取出元素前要判断队前元素序号是否超出滑动窗口前端)需要用到一个新的东西deque(双端队列),笔试时使用的是stack(栈)。classSolution{public:vectormaxSlidingWi
- leetcode153.寻找旋转排序数组中的最小值
ゞ 正在缓冲99%…
算法leetcode数据结构
思路源于【小白都能听懂的算法课】【力扣】【Leetcode153】寻找旋转排序数组中的最小值|二分查找|数组classSolution{publicintfindMin(int[]nums){intleft=0,right=nums.length-1;while(left<=right){intmid=(right-left)/2+left;//left和right处于单调区间中那么left处就是
- 28_跨域
东东__net
前端javascript开发语言
目录promisepromise的基本语法asyncawaittrycatchpromise静态方法跨域跨域的解决方案1-cors编辑2-jsonp方案3-代理服务器promisepromise是一个es6新增的语法承诺的意思作用:是专门用来解决回调地狱!!!!promise的基本语法//基本语法://Promise中写异步代码//letp1=newPromise(function(resolve
- LeetCode 74.搜索二维矩阵
CodingBoyPP
LeetCodeleetcode矩阵算法
问题详情:LeetCode74.搜索二维矩阵1.问题思路由题可知,整个数组从上至下,从左至右都是有序的。所以这里我们可以使用二分查找法。2.代码实现通过遍历每行,对行内数据进行二分查找。classSolution{publicbooleansearchMatrix(int[][]matrix,inttarget){booleanresult=false;//每一层使用二分法进行遍历。for(int
- 《强化学习基础概念:四大模型与两大损失》
KangkangLoveNLP
基础知识强化学习网络人工智能算法机器学习pythonprompt
强化学习基础概念一、策略模型1.策略的定义2.策略的作用3.策略模型二、价值模型1.价值函数的定义(1)状态值函数(StateValueFunction)(2)动作值函数(ActionValueFunction)2.价值函数的作用(1)评估策略(2)指导策略改进(3)帮助决策3.价值模型三、奖励模型奖励模型的定义奖励模型的作用奖励模型的类型奖励模型总结四、参考模型参考模型的定义参考模型的应用参考模
- 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的表,其有一