sql server新增数据时主键自动生成

sql server新增数据时主键自动生成
生成规则为四位年份+二位月份+三位流水号
如:201812001、201812002
这个应该怎么解决,目前思路是写函数,函数应该怎么写,求各位大神帮忙

create function getTestUID()
returns VARCHAR(10)
as
BEGIN
DECLARE @UID VARCHAR(10)
DECLARE @UYEARMOTHN VARCHAR(6)
DECLARE @MaxId VARCHAR(10)
DECLARE @SORE INT
set @UYEARMOTHN = CONVERT(varchar(6),GETDATE(),112) --如果不想取当前年月的话,根据你的情况 直接赋值为 201802
select @MaxId = isnull(max(uId),0) from test222 -- 注意改成自己的表名
IF (@MaxId=0 )
BEGIN
SET @UID = @UYEARMOTHN+'001' --建议流水号设大些吧, 下面的判断相应的改
END
ELSE
BEGIN
SET @SORE = Convert(int,RIGHT(@MaxId,3))
IF(@SORE>=99)
BEGIN
set @UID = @UYEARMOTHN + convert(VARCHAR,(@SORE+1))
END
ELSE IF(@SORE>=9)
BEGIN
set @UID = @UYEARMOTHN + '0'+convert(VARCHAR,(@SORE+1))
END
ELSE IF(@SORE>0)
BEGIN
set @UID = @UYEARMOTHN + '00'+convert(VARCHAR,(@SORE+1))
END
END

RETURN @UID

END

select dbo.getTestUID()

/**
*
* @param start 编号开头
* @param num 从数据库查询出的最大编号
* @return
*/
public static String getNum(String start,String num){
String n = num.substring(0, 3);
if(!n.equals(start)){
System.out.println("编号的开头于数据库取得的编号开头不同");
return "";
}
String strDate = "";//流水号时间
SimpleDateFormat sdf = new SimpleDateFormat("yyy-MM-dd");
Date date = new Date();
//格式化当前时间,并按字符‘-’分隔
String[] sd = sdf.format(date).split("-");
//截取编号中的日期
String time = num.substring(3, 11).toString();
for(int i=0;i strDate += sd[i];
}
//如果当天或者表中没有记录,返回当天第一条记录
if(!time.equals(strDate) || num.equals("")){
return start + strDate + "0001";
}
//截取编号最后的流水号
String end = num.substring(11, 15);
String s2 = "";
int lg = Integer.parseInt(end);
//对流水号结尾的四位数字进行判断,以便增加
if(lg>0&lg s2 = "000"+(lg+1);
}else if(lg>=9 && lg s2 = "00"+(lg+1);
}else if(lg>=99 && lg s2 = "0"+(lg+1);
}else if(lg>999 && lg<9999){
s2 = "" + (lg+1);
}
//返回自动生成的流水号
return start+= strDate + s2;
}
可以根据我这个demo写,不知道是不是这个意思