- 大龄Android程序员经验分享:刚迈过 35 岁分水岭,和大家说点儿心里话
像程序那样思考
安卓程序员资讯移动开发android程序员
不知道是不是整天都带着口罩的缘故,感觉这周的工作效率很低,晚上回家写技术文章效率也低,今天决定水一篇……不不不,今天我想和大家分享分享我这么多年的一些经验和感悟。其实我的简历并不出彩,没有大厂的工作经验,甚至我还在外包公司工作了好几年,走过很多弯路,掉进去很多坑,分享出来,大家引以为戒。说说我的起点我02年高考,分数并不出色,只比一本线高50分(非高考大省),这个分数很尴尬,上个好点儿双一流要么在
- 老程序员经验分享!教你避免面试失败4大招!
菠萝虾大战皮皮鸡
毕业季已到,很多初出茅庐的应届毕业生们都要开始自己的新征程了。小编为大家精心整理了几个老前辈的面试经验!只要注意了以下几点无论是校招还是社招都会让你在程序员的面试中,拔得头筹大放异彩!1说得太少!尤其是那些开放式的问题,如“请介绍下你自己”或“请讲一下你曾经解决过的复杂问题”。面试官会通过你对这些技术和非技术问题的回答来评估你的激情。也会通过模拟团队氛围和与你的交流互动来判断你的经验和能力。所以,
- 15年程序员经验分享:40个改变你编程技能的小技巧!
编程如何节省更多的时间,犯更少的错误?最近,这样一份「心得」火了。这位名叫KeskNoren的软件工程师在Medium上分享了一篇博文——「40Tipsthatwillchangeyourcodingskillsforever」,获得3.5k点赞。40个将永久改变你编程技能的小技巧,你值得拥有~除了软件工程师以外,KeskNoren还是一位全栈工程师。他用15年的工作经验,总结出来一些对职业生涯有
- 字节资深程序员经验分享——学习后端之路
Palp1tate
经验分享学习
入门后端后端没有界面,代码写完不知道能有什么用、能给谁用。选一个熟悉的编程语言,例如go、java,自己写一个网站,有文章发布和展示功能。这样就能直观的感受到后端在互联网世界中的作用。青训营的大项目就能起到这个作用。我知道后端程序可以做数据的增删改查了,我要深入的去学习一个语言的技术栈。选哪个呢?Java、Golang、Python、C/C++等等。服务端方向:字节Golang;美团、阿里、京东等
- 过来的程序员经验分享
futurebp
转载和摘录工作创业生活sqlserver医疗产品
展望未来,总结过去10年的程序员生涯,给程序员小弟弟小妹妹们的一些总结性忠告走过的路,回忆起来是那么曲折,把自己的一些心得体会分享给程序员兄弟姐妹们,虽然时代在变化,但是很可能你也会走我已经做过的10年的路程,有些心得体会你可以借鉴一下,觉得说得有道理的你就接纳,觉得说得没道理的,你就抛弃,以下是我发自内心的,给大家的忠告,特别是针对那些小弟弟妹妹们。01.自己的户口档案、养老保险、医疗保险、住房
- Python入门,如何规划?12年程序员经验分享
Python导师文雀
Python经验分享python编程语言人工智能大数据自然语言处理
Python是一种简单的、解释型的、交互式的、可移植的、面向对象的超高级语言。Python作为一种功能强大且通用的编程语言而广受好评,它具有非常清晰的语法特点,适用于多种操作系统,目前在国际上非常流行,正得到越来越多的应用。因此Python也成为了程序员能力模型中非常重要的一个技能,这对程序员职业发展的重要性由此可见。很多新手在面对“怎样规划Pythoon的学习计划”时,该做什么选择也很重要。这一
- 程序员经验分享:2021年字节跳动+京东+美团面试总结
最新Java开发面试
程序员java后端面试
前言Java作为最全面的语言,国内开发者也是最多的,Java综合起来各方面都不错,在大部分场景下是一种稳健的技术选择。加上近年来安卓的推动,目前也是最流行的一种语言。现在Java的就业市场看起来还是挺大的,而且工资也是比较可观的,**但我为什么说是看起来呢?**其实,最主要的原因还是市场决定的,每年涌入市场的Java开发人员应该是最多的,但是市场上Java初级开发人员早已经饱和了,也就造成了就业市
- 2021春招字节面经,4年老程序员经验分享,已拿到offer
程序媛-双喜
面试Java程序员java面试
前言:此篇文章写给有四年工作经验的JAVA面试者,主要记录我长达两个月的面试道路。希望对你们有帮助!总共面试了6轮!不过最终还是拿到啊了字节的offer~第一轮:(30分钟左右)1.,先自我介绍下,主要介绍自己会什么2.问了一下现在工作的情况3.介绍了一下公司现在的项目,以及入职之后,我要担任的职位第二轮:(30分钟)1.HR介绍重点介绍了一下公司现在的项目,并且要我提出改进方案。2.我提出的是的
- BATJ大厂程序员经验分享:裸辞不慌,两个月逆袭阿里巴巴,记录我的大厂面试之旅
Nginx开发工程师
程序员面试android移动开发
前言虽然经济复苏的很快国内,但是依然很多同窗年初跳槽的计划被搁置。虽然计划被打乱,可是这也给咱们留出时间更好的准备面试。很多公司裁人、降薪甚至倒闭,以后只会更难。面试看了很多面试系列的文章,都是由点及面的技术性文章,但真正的面试并不至于此,长时间的准备也容易对目标产生偏移,今天推荐给你们一篇阿里面试官的文章,看看大厂的面试官是怎么想的。算法阿里面试官:“我也知道尽管不少人都讨厌”面试造航母,工做螺
- BATJ大厂程序员经验分享:裸辞不慌,两个月逆袭阿里巴巴,记录我的大厂面试之旅
Android725
面试学习进阶程序人生Android移动开发
知道自己要什么很重要,知道自己在做什么很重要,你,我永远在路上…前言虽然经济复苏的很快国内,但是依然很多同窗年初跳槽的计划被搁置。虽然计划被打乱,可是这也给咱们留出时间更好的准备面试。很多公司裁人、降薪甚至倒闭,以后只会更难。面试看了很多面试系列的文章,都是由点及面的技术性文章,但真正的面试并不至于此,长时间的准备也容易对目标产生偏移,今天推荐给你们一篇阿里面试官的文章,看看大厂的面试官是怎么想的
- 程序员经验分享:46道面试题带你了解中高级Android面试,面试必问
m0_56260125
程序员android
**新技术层出不穷,去年kotlin到如今Flutter,技术迭代,你是否会变得固步自封?**那么看本篇文章帮你解决问题,让你知道怎么样学习,学习那些技术点才能不被时代的迭代快速淘汰!首先,先说一下百度丶腾讯丶阿里技术岗位的一般面试流程1.Android开发的几个阶段我的10年开发生涯中,有9年都是做Android相关开发,以我个人的经历来看,Android开发市场分为以下几个阶段,也许不是特别准
- 十年开发技术 Bug 总结,程序员经验分享
厚海
技术总结bug思维
作为一名开发人员,项目出现bug是避免不了的。无论你是一名初入职场的小白,还是拥有经验丰富的大佬,只要经常写代码,梳理业务逻辑,很难免不出bug。正所谓常在冰上走,难免不湿鞋。记得以前经常听人说,如果你没有把系统搞宕机过,就不是一名合格的CTO,成为一名出色的开发人员,经验都是一个一个积累起来的。那么怎么能避免出现bug呢,写出没有问题的代码呢,我来分享一下我的经验。一、需求开始开发之前一定要先把
- 15年程序员经验分享:40个改变你编程技能的小技巧!
依然范特稀西
Android最佳实践程序员Java全栈开发设计模式编程技巧
编程如何节省更多的时间,犯更少的错误?最近,这样一份「心得」火了。这位名叫KeskNoren的软件工程师在Medium上分享了一篇博文——「40Tipsthatwillchangeyourcodingskillsforever」,获得3.5k点赞。40个将永久改变你编程技能的小技巧,你值得拥有~除了软件工程师以外,KeskNoren还是一位全栈工程师。他用15年的工作经验,总结出来一些对职业生涯有
- 自学转行至程序员经验分享
SyntaxError
pythonjavagolang自学程序员
这是本人真实的转行经历,其实早就想整理出一篇文章了,无奈前几天工作任务繁重,自己可支配时间较少。发这篇文章的目的,也是给大家提供一些参考,避免一些坑。文章内的观点只代表我个人的看法,不绝对。如果有其他的问题,欢迎在文章的评论区一起讨论。:)背景介绍 我先介绍一下我自己,以及我是如何萌生转行至程序员的这个想法的。 我是18年毕业于某985的机械设计制造及其自动化专业,了解这个专业的应该都知道这是
- 构建团队的知识库以及打造需求和bug一体的开发管理体验
webmote
.netcore深度剖析架构团队协作dotnet
为了加快团队的敏捷开发效率,并使得需求、开发、测试无缝衔接,必须准备有关程序员的团队管理利器。而今市场上流行的是禅道、TDD、confluence、jira等各类工具流派,当然我非常看好CSDN,不过CSDN暂时并没有推出类似的管理工具,作为一款主打程序员经验分享的主流博客阵地,缺失了团队的管理,不能不说是一种遗憾。这篇文章但愿能被CSDN的产品看到,也许不但能带动CSDN的发展,也可以给国内程序
- 15年程序员经验分享:40个改变你编程技能的小技巧!
依然饭特稀西
程序员前端javaandroid编程
编程如何节省更多的时间,犯更少的错误?最近,这样一份「心得」火了。这位名叫KeskNoren的软件工程师在Medium上分享了一篇博文——「40Tipsthatwillchangeyourcodingskillsforever」,获得3.5k点赞。40个将永久改变你编程技能的小技巧,你值得拥有~除了软件工程师以外,KeskNoren还是一位全栈工程师。他用15年的工作经验,总结出来一些对职业生涯有
- 程序员经验分享(转)
名贤集
好文章
看不到实物,客户不会知道自己想要什么一个功能性原型系统的展示,能够省下无谓低效的赘述。只要给予足够的时间,任何安全措施都不安全安全是目前系统运维的重大挑战,我们每时每刻都想方设法来保护系统和数据,但是黑客只要成功一次,我们所有努力就极有可能都付诸东流。系统被攻破后造成的影响,依赖于事前的准备功夫如果能够预先估计防护系统失效的后果,做足准备措施,例如:把关键数据单独分离存储,对数据进行加密等,那么或
- 自学转行至程序员经验分享
SyntaxError
pythonjavagolang自学程序员
这是本人真实的转行经历,其实早就想整理出一篇文章了,无奈前几天工作任务繁重,自己可支配时间较少。发这篇文章的目的,也是给大家提供一些参考,避免一些坑。文章内的观点只代表我个人的看法,不绝对。如果有其他的问题,欢迎在文章的评论区一起讨论。:)背景介绍 我先介绍一下我自己,以及我是如何萌生转行至程序员的这个想法的。 我是18年毕业于某985的机械设计制造及其自动化专业,了解这个专业的应该都知道这是
- Java程序员经验分享:如何在面试中介绍自己的项目经验?
Java丶python攻城狮
在面试时,经过寒暄后,一般面试官会让你介绍项目经验。常见的问法是:“说下你最近的(或最拿得出手的)一个项目”。可能不少程序员对此没准备,说起来磕磕巴巴,甚至有人说出项目经验从时间段或技术等方面和简历上的不匹配,这样就会造成如下的后果:第一印象就不好了,至少会感觉该候选人表述能力不强。一般来说,面试官会根据程序员介绍的项目背景来提问题。假设面试时会问10个问题,那么至少有5个问题会根据程序员所介绍的
- Flink实时计算-深入理解Checkpoint和Savepoint
LakeShen说
我是LakeShen,专注大数据技术分享,程序员经验分享,互联网科技分享。如果我的文章对你有帮助,希望你能点赞或者关注我,你的鼓励,就是我前进的最大动力。关注就完事了。前言为了保证程序的容错恢复以及程序启动时其状态恢复,几乎所有的Flink实时任务都会开启Checkpoint或者触发Savepoint进行状态保存。为了使得用户更加理解这两点区别,本文结合Flink1.9版本,重点讲述FlinkCh
- 程序员经验分享(转)
kofsky
工作windowsHibernate语言Delphi产品
“又是一年毕业时”,看到一批批学子离开人生的象牙塔,走上各自的工作岗位;想想自己也曾经意气风发、踌躇满志,不觉感叹万千……本文是自己工作6年的经历沉淀或者经验提炼,希望对所有的软件工程师们有所帮助,早日实现自己的人生目标。本文主要是关于软件开发人员如何提高自己的软件专业技术方面的具体建议,前面几点旨在确定大的方向,算是废话吧。谨以此文献给那个自己为你奉献3年青春与激情的开发团队。还有团队成员:PP
- 程序员经验分享
kofsky
编程软件测试项目管理matlab读书
“又是一年毕业时”,看到一批批学子离开人生的象牙塔,走上各自的工作岗位;想想自己也曾经意气风发、踌躇满志,不觉感叹万千……本文是自己工作6年的经历沉淀或者经验提炼,希望对所有的软件工程师们有所帮助,早日实现自己的人生目标。本文主要是关于软件开发人员如何提高自己的软件专业技术方面的具体建议,前面几点旨在确定大的方向,算是废话吧。谨以此文献给那个自己为你奉献3年青春与激情的开发团队。还有团队成员:PP
- 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的表,其有一