电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

用Java實(shí)現(xiàn)自動(dòng)在數(shù)據(jù)庫(kù)表中生成ID號(hào)

瀏覽:98日期:2024-06-13 18:54:37
內(nèi)容: 版權(quán)聲明:任何獲得Matrix授權(quán)的網(wǎng)站,轉(zhuǎn)載時(shí)請(qǐng)務(wù)必以超鏈接形式標(biāo)明文章原始出處和作者信息及本聲明作者:Flyingis原文:http://www.matrix.org.cn/resource/article/43/43947_Java_ID.html關(guān)鍵字:java,自動(dòng)生成,字典ID 前段時(shí)間用Struts開(kāi)發(fā)了一個(gè)B/S結(jié)構(gòu)的信息管理系統(tǒng),其中有一個(gè)功能是要求管理員能夠?qū)?shù)據(jù)字典進(jìn)行修改,數(shù)據(jù)字典的表結(jié)構(gòu)基本上都是table(id, name),id為數(shù)據(jù)庫(kù)其它表中所存儲(chǔ)的內(nèi)容,表示方式為A01、A02、A08、B10、B25、C12等等,一個(gè)字典就分配一個(gè)字母作為其ID號(hào)的標(biāo)識(shí),其實(shí)就是為了調(diào)試時(shí)方便,在其它的表中判斷該字典的名稱(chēng)。因此對(duì)于一個(gè)特定的字典表來(lái)說(shuō),其ID號(hào)排序應(yīng)該是A01、A02、A03、A04…… 在對(duì)字典內(nèi)容進(jìn)行刪除的時(shí)候并不需要考慮什么,直接使用DELETE語(yǔ)句就可以了。關(guān)鍵是添加字典信息時(shí),管理員需要在表單中填寫(xiě)的是table中的name字段,ID號(hào)如何生成就需要自己用代碼來(lái)實(shí)現(xiàn)(包括ID號(hào)的01號(hào)空缺,中間有斷開(kāi)等情況)。下面是我設(shè)計(jì)的代碼,其中關(guān)鍵的地方都有詳細(xì)的注釋?zhuān)?* * 功能:增加字典信息時(shí),自動(dòng)生成最小的ID號(hào)碼 * 參數(shù):String 字典表名稱(chēng) first 字典ID的首字母,代表唯一的字典 * 返回:String 生成的最小ID號(hào)碼 */public String getId(String table, String first) {// 所有除去首字母后的ID號(hào)碼--整型,例如:11int[] sid;// 所有原始ID號(hào)碼,例如:A11String[] rid;// 除去首字母后最小的ID號(hào)碼--字符串String sid_new = null;// 程序返回的最小的原始ID號(hào)碼String rid_new = null; // 循環(huán)參數(shù)int i = 0;int k = 0;con = DatabaseConnection.getConnection('jdbc/wutie');Statement stm = null;ResultSet rst = null;RowSet rowRst = null;String sql = 'SELECT * FROM ' + table + ' order by id';try { if (con.isClosed()) { throw new IllegalStateException('error.sql.unexpected'); } stm = con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE); rst = stm.executeQuery(sql); while (rst.next()) { k++; } sid = new int[k]; rid = new String[k]; rst = stm.executeQuery(sql); // 如果不存在結(jié)果集,則直接在first字母后面加01,例如first='A',rid_new=A01 if (!rst.first()) { rid_new = first.concat('01'); return rid_new; } // 如果存在結(jié)果集,則將表中所有ID號(hào)存入數(shù)組中,并轉(zhuǎn)換為整型數(shù)據(jù) else { /* while (rst.next()) { rid[i] = rst.getString('id'); sid[i] = Integer.parseInt(rid[i].substring(1)); i++; } */ for (rst.previous(); rst.next(); i++) { rid[i] = rst.getString('id'); sid[i] = Integer.parseInt(rid[i].substring(1)); } // 如果第一條記錄ID號(hào)不為fisrt+01,例如A03、A05、A18等,則返回新增數(shù)據(jù)的ID號(hào)為A01 if (sid[0] != 1) { rid_new = first.concat('01'); return rid_new; } // 如果第一條記錄ID號(hào)為first+1,即A1,則執(zhí)行下面語(yǔ)句 else { // 如果總記錄數(shù)只有一條,例如A1,則返回新增數(shù)據(jù)為A02 if (i == 1) { rid_new = first.concat('02'); return rid_new; } else { for (int j = 1; j < k; j++) { // 如果相鄰兩條記錄ID號(hào)的整數(shù)位相差1,則保存新增數(shù)據(jù)ID號(hào)整數(shù)位是前一位ID號(hào)整數(shù)位加1 if (sid[j] == sid[j-1] + 1) { if (sid[j] < 9) { sid_new = String.valueOf(sid[j] + 1); rid_new = first.concat('0').concat(sid_new); } else { sid_new = String.valueOf(sid[j] + 1); rid_new = first.concat(sid_new); } }// 如果相鄰兩條記錄ID號(hào)的整數(shù)位相差非1,則返回新增數(shù)據(jù)ID號(hào)整數(shù)位是前一位ID號(hào)整數(shù)位加1if (sid[j] != sid[j-1] + 1) {if (sid[j-1] < 9) { sid_new = String.valueOf(sid[j-1] + 1); rid_new = first.concat('0').concat(sid_new); return rid_new;}else { sid_new = String.valueOf(sid[j-1] + 1); rid_new = first.concat(sid_new); return rid_new;} }} return rid_new; } } } }catch (SQLException e) {e.printStackTrace();throw new RuntimeException('error.sql.runtime');}finally {try {stm.close();con.close();}catch (SQLException e1) {e1.printStackTrace();throw new RuntimeException('error.sql.runtime');}}} 注意:之所以生成A01而不是A1,是因?yàn)樵赟QLServer2000中根據(jù)ID號(hào)正確排序的需要,如果按照升序排列,A1后面是A10、A11等,而不是A2。另外,在Hibernate中有多種自動(dòng)生成ID字段的方法,但是這個(gè)項(xiàng)目比較小,我沒(méi)有使用Hibernate中間件,這里提供的只是生成字典ID字段的一種簡(jiǎn)單思路,只能用于字典項(xiàng)不多于100項(xiàng)的情況,一般的情況可以滿(mǎn)足了,但如果超過(guò)100項(xiàng)只需簡(jiǎn)單修改一下代碼,不足之處還請(qǐng)大家多指教!資源·Matrix-Java開(kāi)發(fā)者社區(qū):http://www.matrix.org.cn/ Java, java, J2SE, j2se, J2EE, j2ee, J2ME, j2me, ejb, ejb3, JBOSS, jboss, spring, hibernate, jdo, struts, webwork, ajax, AJAX, mysql, MySQL, Oracle, Weblogic, Websphere, scjp, scjd 版權(quán)聲明:任何獲得Matrix授權(quán)的網(wǎng)站,轉(zhuǎn)載時(shí)請(qǐng)務(wù)必以超鏈接形式標(biāo)明文章原始出處和作者信息及本聲明作者:Flyingis原文:http://www.matrix.org.cn/resource/article/43/43947_Java_ID.html關(guān)鍵字:java,自動(dòng)生成,字典ID 前段時(shí)間用Struts開(kāi)發(fā)了一個(gè)B/S結(jié)構(gòu)的信息管理系統(tǒng),其中有一個(gè)
標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 阳光模拟试验箱_高低温试验箱_高低温冲击试验箱_快速温变试验箱|东莞市赛思检测设备有限公司 | EDLC超级法拉电容器_LIC锂离子超级电容_超级电容模组_软包单体电容电池_轴向薄膜电力电容器_深圳佳名兴电容有限公司_JMX专注中高端品牌电容生产厂家 | 托利多电子平台秤-高精度接线盒-托利多高精度电子秤|百科 | 污水提升器,污水提升泵,地下室排水,增压泵,雨水泵,智能供排水控制器-上海智流泵业有限公司 | 蜗轮丝杆升降机-螺旋升降机-丝杠升降机厂家-润驰传动 | 专注提供国外机电设备及配件-工业控制领域一站式服务商-深圳市华联欧国际贸易有限公司 | 伸缩器_伸缩接头_传力接头-巩义市润达管道设备制造有限公司 | 高速龙门架厂家_监控杆_多功能灯杆_信号灯杆_锂电池太阳能路灯-鑫世源照明 | 睿婕轻钢别墅_钢结构别墅_厂家设计施工报价 | 浙江宝泉阀门有限公司 | 凝胶成像仪,化学发光凝胶成像系统,凝胶成像分析系统-上海培清科技有限公司 | 齿轮减速马达一体式_蜗轮蜗杆减速机配电机-德国BOSERL齿轮减速电动机生产厂家 | 黄石东方妇产医院_黄石妇科医院哪家好_黄石无痛人流医院 | 蓄电池回收,ups电池后备电源回收,铅酸蓄电池回收,机房电源回收-广州益夫铅酸电池回收公司 | 南京种植牙医院【官方挂号】_南京治疗种植牙医院那个好_南京看种植牙哪里好_南京茀莱堡口腔医院 尼龙PA610树脂,尼龙PA612树脂,尼龙PA1010树脂,透明尼龙-谷骐科技【官网】 | 河南卓美创业科技有限公司-河南卓美防雷公司-防雷接地-防雷工程-重庆避雷针-避雷器-防雷检测-避雷带-避雷针-避雷塔、机房防雷、古建筑防雷等-山西防雷公司 | 100国际学校招生 - 专业国际学校择校升学规划 | 北京翻译公司-专业合同翻译-医学标书翻译收费标准-慕迪灵 | 大流量卧式砂磨机_强力分散机_双行星双动力混合机_同心双轴搅拌机-莱州市龙跃化工机械有限公司 | 全自动翻转振荡器-浸出式水平振荡器厂家-土壤干燥箱价格-常州普天仪器 | 骨灰存放架|骨灰盒寄存架|骨灰架厂家|智慧殡葬|公墓陵园管理系统|网上祭奠|告别厅智能化-厦门慈愿科技 | 蒸压釜_蒸养釜_蒸压釜厂家-山东鑫泰鑫智能装备有限公司 | 长江船运_国内海运_内贸船运_大件海运|运输_船舶运输价格_钢材船运_内河运输_风电甲板船_游艇运输_航运货代电话_上海交航船运 | 银川美容培训-美睫美甲培训-彩妆纹绣培训-新娘化妆-学化妆-宁夏倍莱妮职业技能培训学校有限公司 临时厕所租赁_玻璃钢厕所租赁_蹲式|坐式厕所出租-北京慧海通 | 珠宝展柜-玻璃精品展柜-首饰珠宝展示柜定制-鸿钛展柜厂家 | 江苏全风,高压风机,全风环保风机,全风环形高压风机,防爆高压风机厂家-江苏全风环保科技有限公司(官网) | 学习安徽网| 鹤壁创新仪器公司-全自动量热仪,定硫仪,煤炭测硫仪,灰熔点测定仪,快速自动测氢仪,工业分析仪,煤质化验仪器 | 股指期货-期货开户-交易手续费佣金加1分-保证金低-期货公司排名靠前-万利信息开户 | 东莞市海宝机械有限公司-不锈钢分选机-硅胶橡胶-生活垃圾-涡电流-静电-金属-矿石分选机 | 防爆电机-高压防爆电机-ybx4电动机厂家-河南省南洋防爆电机有限公司 | 盘古网络技术有限公司| 并离网逆变器_高频UPS电源定制_户用储能光伏逆变器厂家-深圳市索克新能源 | 济南网站建设_济南网站制作_济南网站设计_济南网站建设公司_富库网络旗下模易宝_模板建站 | 升降机-高空作业车租赁-蜘蛛车-曲臂式伸缩臂剪叉式液压升降平台-脚手架-【普雷斯特公司厂家】 | 中国产业发展研究网 - 提供行业研究报告 可行性研究报告 投资咨询 市场调研服务 | 存包柜厂家_电子存包柜_超市存包柜_超市电子存包柜_自动存包柜-洛阳中星 | 高压无油空压机_无油水润滑空压机_水润滑无油螺杆空压机_无油空压机厂家-科普柯超滤(广东)节能科技有限公司 | 5L旋转蒸发器-20L-50L旋转蒸发器-上海越众仪器设备有限公司 | 上海律师咨询_上海法律在线咨询免费_找对口律师上策法网-策法网 广东高华家具-公寓床|学生宿舍双层铁床厂家【质保十年】 | 合肥地磅_合肥数控切割机_安徽地磅厂家_合肥世佳电工设备有限公司 |