- Java 笔记 lambda
五行缺弦
Java笔记java笔记
✅Lambda基本语法(parameters)->expression或(parameters)->{statements}//无参数Runnabler=()->System.out.println("Hello");//单个参数(小括号可省略)Consumerc=s->System.out.println(s);//多参数+多语句Comparatorcomp=(a,b)->{System.out
- oldguo-MySQL 8.0 OCP 原题解析-Q23
MySQL_oldguo
Question23:Examinethecommand,whichexecutesuccessfully:shell>mysqld--initialize-insecureWhichstatementistrue?A)Theinstallationcreatesatemporarytestenvironmentwithdatainthe/tmpdirectory.B)Theinstallatio
- LangChain specific default response
营赢盈英
AIlangchainpythonopenaiapi
题意:LangChain特定的默认响应问题背景:usingLangChainandOpenAI,howcanIhavethemodelreturnaspecificdefaultresponse?forinstance,let'ssayIhavethesestatement/responses使用LangChain和OpenAI时,如何让模型返回特定的默认响应?例如,假设我有如下的陈述/响应:St
- JavaScript手录04-【if-else&switch】语句
一、表达式、语句和函数语句(Statements)语句是JavaScript执行的基本单位,用于完成特定操作(如判断、循环、赋值等)。语句通常以分号;结束(某些情况下可省略),多个语句可以组成代码块(用{}包裹)。特点:语句的执行会产生某种行为(如改变变量值、控制流程)语句本身没有返回值(或返回值为undefined)常见语句:if-else、for、while、return、break等。函数(
- java--JDBC
爱吃小土豆豆豆豆
java
JDBCJDBC:(JavaDataBaseConnectivity),就是使用Java语言操作关系型数据库的一套API。在pom.xml文件中引入依赖mysqlmysql-connector-java8.0.30org.junit.jupiterjunit-jupiter5.9.3testJDBC程序执行DML语句?DQL语句?DML语句:introwsAffected=statement.ex
- com.baomidou.mybatisplus.core.exceptions.MybatisPlusException:
Cause:com.baomidou.mybatisplus.core.exceptions.MybatisPlusException:Failedtoprocess,pleaseexcludethetableNameorstatementId.ErrorSQL:selectc.idfromcode_scanning_attributioncleftjoinuser_relationuonc.us
- Codeforces Round 958 (Div. 2 ABCDE题) 视频讲解
阿史大杯茶
Codeforces算法c++数据结构
A.SplittheMultisetProblemStatementAmultisetisasetofnumbersinwhichtherecanbeequalelements,andtheorderofthenumbersdoesnotmatter.Forexample,{2,2,4}\{2,2,4\}{2,2,4}isamultiset.YouhaveamultisetSSS.Initiall
- PHP防范SQL注入攻击的5种高效方法与实践
独立开发者阿乐
综合性原创phpsql开发语言攻击PDOMySQLiSQL注入
文章目录PHP防止SQL注入攻击的全面指南一、SQL注入攻击概述1.1什么是SQL注入1.2SQL注入的危害1.3常见SQL注入示例二、PHP防御SQL注入的核心策略2.1使用预处理语句(PreparedStatements)PDO预处理示例MySQLi预处理示例2.2输入验证与过滤2.3使用ORM框架LaravelEloquent示例2.4最小权限原则三、进阶防御策略3.1使用Web应用防火墙(
- Apache Ignite 中 WHERE 子句中的子查询(Subqueries in WHERE Clause)的执行方式
这段内容是关于ApacheIgnite中WHERE子句中的子查询(SubqueriesinWHEREClause)的执行方式的说明。理解这段内容对于编写高效的SQL查询、避免性能瓶颈非常重要。下面我将为你逐句解释并深入理解这段内容。原文翻译+解释原文:SELECTqueriesusedinINSERTandMERGEstatementsaswellasSELECTqueriesgeneratedb
- DB restore point and datagurad
weixin_33836223
数据库c/c++
########12.5.1FlashingBackaPhysicalStandbyDatabasetoaSpecificPoint-in-TimeThefollowingstepsdescribehowtoavoidre-creatingaphysicalstandbydatabaseafteryouissuedtheOPENRESETLOGSstatementontheprimarydatab
- Python for循环
dengdieli5313
python
Pythonfor循环可以遍历任何序列的项目,如一个列表或者一个字符串。for循环的语法结构如下:foriterating_varinsequence:statements(s)最简单的形式如下,循环10次。1foriinrange(10):2print("loop:",i)输出为1loop:02loop:13loop:24loop:35loop:46loop:57loop:68loop:79lo
- 《MyBatis的运行原理》
一.MyBatis是什么?MyBatis是⼀个开源、轻量级的数据持久化框架,是JDBC和Hibernate的替代⽅案,MyBatis内部封装了JDBC,简化了加载驱动、创建连接、创建statement等繁杂的过程,开发者只需要关注SQL语句本身。二.MyBatis执行流程1.MyBatis与JDBC想要学习了解MyBatis,我们首先需要从JDBC入手并立足于JDBC,才能深入的理解MyBatis
- GaussDB in的用法
小云数据库服务专线
gaussdb数据库sql
1in的作用in运算符允许您在WHERE子句中指定多个值。in运算符是多个OR条件的简写。2in的语法selectcolumn_name(s)fromtable_namewherecolumn_namein(value1,value2,...);或者selectcolumn_name(s)fromtable_namewherecolumn_namein(selectstatement);3in使用
- Java8新特性
1.Lambda表达式Lambda表达式是JDK8引入的一种函数式编程特性,允许以简洁的语法实现函数式接口(只有一个抽象方法的接口)。(parameters)->expression或(parameters)->{statements;}参数列表:可省略参数类型(编译器自动推断),空参数时保留括号。箭头符号->:分隔参数和实现逻辑。表达式或代码块:单行表达式可省略大括号和return;多行语句需用
- c语言中,break可以跳出if语句吗
是的,在C语言中,break语句可以用来跳出if语句。例如:if(condition){//若condition为真,执行以下语句statement1;statement2;...//若希望在执行完statement2之后跳出if语句,可以使用break语句break;statement3;statement4;...}在上述代码中,如果condition为真,那么将会执行statement1和s
- 解密seata全局锁(一)
新world
seatajava
解密seata全局锁从哪开始分析呢?StatementProxyExecuteTemplateexecuteAutoCommitFalse总结从哪开始分析呢?seata的基本原理可以参照2PC,而本地事务方面的实现是通过代理方式实现扩展,如:在执行提交前后生成image等StatementProxy熟悉JDBC的同学应该都知道Statement的作用吧,seata实现Statement功能的代理类
- web后端框架MyBatis
猿力觉醒
java后端mybatis
目录前言1.xml配置方式开发步骤2.注解方式开发步骤前言mybatis是一个优秀的基于java的持久层框架,它内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。mybatis通过xml或注解的方式将要执行的各种statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的
- java中打印sql,利用JDBC的PrepareStatement打印真实SQL的方法详解
weixin_39878549
java中打印sql
前言本文主要给大家介绍了关于利用JDBC的PrepareStatement打印真实SQL的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍:我们知道,JDBC的PrepareStatement优点多多,通常都是推荐使用PrepareStatement而不是其基类Statment。PrepareStatement支持?占位符,可以将参数按照类型转自动换为真实的值。既然这一过程是自动的,封装
- python分支语句_python入门基础教程10 python的分支语句
weixin_39604280
python分支语句
if分支语句分支语句的作用是在某些条件控制下有选择的执行实现一定功能语句块。if分支语句则是当if后的条件满足时,if下的语句块被执行,语法格式如下所示:if:statements让我们看看代码吧。>>>sex='male'>>>ifsex=='male':print'Man!'#此处有两次回车键Man!>>>ifsex=='female':print'Woman'#此处有两次回车键>>>if_e
- MyBatis Mapper.xml核心属性详解
代码的余温
mybatisxml
在MyBatis的Mapper.xml文件中,statement标签(如、等)包含多个关键属性,用于定义SQL语句的行为和映射规则。以下是核心属性及其含义:一、基础属性id作用:当前命名空间下SQL语句的唯一标识,必须与对应Mapper接口的方法名一致。示例:对应接口方法UsergetUserById(intid)。parameterType作用:指定输入参数的类型(如java.lang.Inte
- 【JDBC痛点终结者】MyBatis如何优雅解决传统数据库操作的七大难题
码农技术栈
MyBatis数据库mybatistomcatjava开发语言后端性能优化
你是否曾在JDBC的ResultSet和PreparedStatement的海洋中迷失方向?是否被无数重复的模板代码折磨得精疲力尽?本文将带你揭秘MyBatis如何优雅解决JDBC的痛点,让你告别繁琐,拥抱高效!一、先看一个真实场景:JDBCvsMyBatis1.JDBC实现用户查询//JDBC查询用户publicUserfindUserById(intid)throwsSQLException{
- 【Python】For
Herbert_JL
pythonpython开发语言
For基本语法forelementiniterable:statement(s)element:是循环变量,用于存储可迭代对象中当前遍历到的元素。iterable:是需要遍历的可迭代对象,如列表、元组、字典等。for遍历列表fruits=["apple","banana","cherry"]forfruitinfruits:print(fruit)applebananacherryfor遍历字符串
- Mybatis源码,从配置到 mappedStatement/mapper.xml 是如何被解析的?
祁娥安
Javajavamybatis
今天跟大家分享下Mybatis源码,从配置到mappedStatement/mapper.xml解析的知识。1从MybatisAutoConfiguration说开去,mapper文件是怎么扫描的?Ext1:本文源码解析基于mybatis-spring-boot-starter2.1.1,即mybatis3.5.3版本。Ext2:本文主要是对源码的讲解,着重点会是在源码上。我们知道配置SqlSes
- SQLRecoverableException: 关闭的连接 尝试解决办法
一朵梨花压海棠go
java前端服务器
错误效果:[11:31:31][ERROR]-com.alibaba.druid.util.JdbcUtils.close(JdbcUtils.java:109)-closestatementerrorjava.sql.SQLRecoverableException:关闭的连接atoracle.jdbc.driver.PhysicalConnection.needLine(PhysicalConn
- canal同步mysql到kafka_使用Canal同步MySQL数据到Kafka 得到的数据中sql字段无值-问答-阿里云开发者社区-阿里云...
又可乐
这个应该跟你的binlog记录模式有关系,binlog有3中模式,ROW(行模式),Statement(语句模式),Mixed(混合模式)三种模式的用法如下:ROW(行模式):记录那条数据修改了,注意:记录的是这条记录的全部数据,即使只更新了一个字段,binlog里也会记录所有字段的数据优点:他不记录sql语句的上下文信息,日志内容会非常清楚的记录每条数据详细的变更细节,即使只更新了一个字段,bi
- MyBatis初识:为什么选择它?
双力臂404
mybatis基础mybatis开发语言
前言在Java持久层框架的江湖中,MyBatis像一位特立独行的侠客——它既不像JDBC那样需要开发者赤手空拳打天下,也不似Hibernate般用ORM大法将SQL完全封装。这种"中间派"的定位,恰恰解决了开发者在两个极端之间的长期困扰。JDBC的"三座大山"//典型JDBC代码片段Connectionconn=null;PreparedStatementps=null;ResultSetrs=n
- MySQL 8.0 OCP 1Z0-908 题目解析(6)
一只fish
MYSQLOCPmysql数据库
题目021Choosetwo.Whichtwostatementsaretrueaboutthemysql_config_editorprogram?□A)Itprovidesaninterfacetochangemy.cnffiles.□B)Itcanmovedatadirtoanewlocation.□C)Itwilluse[client]optionsbydefaultunlessyoupr
- MySQL 8.0 OCP 1Z0-908 题目解析(19)
一只fish
MYSQLOCPmysql数据库
题目73Choosetwo.WhichtwoarefeaturesofMySQLEnterpriseFirewall?□A)blockingofpotentialthreatsbyconfiguringpre-approvedwhitelists□B)modifyingSQLstatementdynamicallywithsubstitutions□C)recordingincomingSQLst
- 7、垃圾回收调优
很小心的小新
jvmjava笔记垃圾回收调优
查看虚拟机参数:java-XX:PrintFlagsFinal-verson|findstr“GC”调优领域:内存锁竞争cpu占用io确定目标:低延迟还是高吞吐量,选择适合的回收器响应时间优先:CMS、G1,ZGC高吞吐量:PArallelGC最快的GC是不发生GC查看FullGC前后的内存占用,考虑下面几个问题数据是不是太多了resultSet=statement。executeQuery(“s
- MyBatis SQL 执行过程原理分析(附源码) 代理层:Mapper 接口动态代理 路由层:MapperMethod 分发 核心引擎:SqlSession 执行
夜雨hiyeyu.com
mybatissql数据库数据库架构javaspringbootdb
MyBatisSQL执行过程原理分析(附源码)1.代理层:Mapper接口动态代理2.路由层:MapperMethod分发3.核心引擎:SqlSession执行4.执行器:Executor调度5.处理器层:StatementHandler执行6.结果映射:ResultSetHandler转换核心执行流程图关键设计亮点性能优化建议MyBatis的SQL执行过程可以分为6个核心阶段,我们将通过源码逐层
- 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的表,其有一