网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

SQLServer数据库主键及复合主键都有哪些配置

这篇文章主要介绍“SQLServer数据库主键及复合主键都有哪些配置”,在日常操作中,相信很多人在SQLServer数据库主键及复合主键都有哪些配置问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SQLServer数据库主键及复合主键都有哪些配置”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

成都创新互联是一家专注于网站建设、成都网站设计与策划设计,澄江网站建设哪家好?成都创新互联做网站,专注于网站建设10余年,网设计领域的专业建站公司;建站业务涵盖:澄江等地区。澄江做网站价格咨询:18982081108

@Id@GeneratedValue@Column(name="RecId")publicintgetRecId(){returnRecId;}

复合主键个人认为用到的很少,呜呜还是碰到了,由于没有经验,东装西摸,浪费了很长时间才把复合主键配好了,并且还出了很多异常,如下所示:

一个表中可以有多个字段組成的主鍵

createtableEL_TransIdTable(TableNamenvarchar(50),LastTransIdnvarchar(15),Prefixnchar(5),DomainIdnvarchar(10)primarykey(TableName,DomainId))

其中TableName、DomainId两个字段作为此表的主键。

在配置中主要分为两个步骤:

1为复合主键,建立一个复合主键类,这个类包括两个字段,(有几个字段组成主键就包含几个字段)这个复合主键类实现Serializable接口,有public无参的构造方法重写equals和hashcode方法。

2:在实体类里面用idclass标示复合主键类详情如下:

新建复合主键类TableDomainIdPK.java。

packagecom.barcode.Model;importjava.io.Serializable;publicclassTableNameDomainIdPKimplementsSerializable{publicTableNameDomainIdPK(){}privateStringTableName;privateStringDomainId;publicStringgetTableName(){returnTableName;}publicvoidsetTableName(StringtableName){TableName=tableName;}publicStringgetDomainId(){returnDomainId;}publicvoidsetDomainId(StringdomainId){DomainId=domainId;}@OverridepublicinthashCode(){finalintPRIME=31;intresult=1;result=PRIME*result+((TableName==null)0:TableName.hashCode());result=PRIME*result+((DomainId==null)0:DomainId.hashCode());returnresult;}@Overridepublicbooleanequals(java.lang.Objectobj){if(this==obj){returntrue;}if(null==obj){returnfalse;}finalTableNameDomainIdPKother=(TableNameDomainIdPK)obj;if(DomainId==null){if(other.DomainId!=null){returnfalse;}}elseif(!DomainId.equals(other.DomainId)){returnfalse;}if(TableName==null){if(other.TableName!=null){returnfalse;}}elseif(!TableName.equals(other.TableName)){returnfalse;}returntrue;}}

新建实体类EL_TransIdTable.java。

SQLServer数据库主键及复合主键有哪些配置

实体类中的配置如下:

packagecom.barcode.Model;importjava.io.Serializable;importjavax.persistence.Column;importjavax.persistence.Entity;importjavax.persistence.Id;importjavax.persistence.IdClass;importjavax.persistence.Table;@Entity@Table(name="EL_TransIdTable")@IdClass(TableNameDomainIdPK.class)publicclassEL_TransIdTableimplementsSerializable{privateStringTableName;privateStringLastTransId;privateStringPrefix;privateStringDomainId;@Id@Column(name="TableName",nullable=false)publicStringgetTableName(){returnTableName;}publicvoidsetTableName(StringtableName){TableName=tableName;}@Column(name="LastTransId")publicStringgetLastTransId(){returnLastTransId;}publicvoidsetLastTransId(StringlastTransId){LastTransId=lastTransId;}@Column(name="Prefix")publicStringgetPrefix(){returnPrefix;}publicvoidsetPrefix(Stringprefix){Prefix=prefix;}@Id@Column(name="DomainId",nullable=false)publicStringgetDomainId(){returnDomainId;}publicvoidsetDomainId(StringdomainId){DomainId=domainId;}publicvoidPrint_Info(){System.out.println(this.getDomainId()+this.getLastTransId()+this.getPrefix()+this.getTableName());}}

到此,关于“SQLServer数据库主键及复合主键都有哪些配置”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!


文章名称:SQLServer数据库主键及复合主键都有哪些配置
URL标题:http://bjjierui.cn/article/iiioip.html

其他资讯