返回顶部
首页 > 资讯 > 数据库 >怎么用一句SQL解决SQL中断号问题
  • 176
分享到

怎么用一句SQL解决SQL中断号问题

2024-04-02 19:04:59 176人浏览 安东尼
摘要

这篇文章主要讲解了“怎么用一句sql解决SQL中断号问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用一句SQL解决SQL中断号问题”吧!名词解释  

这篇文章主要讲解了“怎么用一句sql解决SQL中断号问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用一句SQL解决SQL中断号问题”吧!

名词解释  断号:比如,连续生成的编号,由于某种操作(通常为删除)后,产生不连续的编号,我们将这种不连续的编号称为断号。  例如,数据库中有一个字段叫合同编号,正常格式为201106_011(表示2011年6月的第11个合同),那么它前面的一个合同编号应该为201106_10,后面的一个应该为201106_12,当我们删除了合同201106_011,就会出现201106_010后面直接是201106_012,这种情况下叫做断号。  传统系统中,像这种断号的情况很常见,比如数据库中的列为递增类型,当删除某行后,就会出现断号,而经常有客户提出需求,不希望出现断号的情况。解决方案通常就是,如果删除了某行数据,那么下次新增时,应该将断号补齐。 问题很简单,解决方法也很简单: 写一个C#方法,用来获取下一条记录的编号:复制代码 代码如下:
 public static int GetNextNumber(int[] iNumList) { int iTempStr = iNumList[0]; //用一个临时变量保存上一条记录的编号 for (var i = 0; i < iNumList.Length - 1; i++) { if (i == 0) { iTempStr = iNumList[i]; } //如果出现断号,则补齐断号 if ((iNumList[i] - iTempStr) > 1) { return iTempStr + 1; } else { iTempStr = iNumList[i]; } continue; } return iNumList[iNumList.Length - 1] + 1; }
当然,这段代码也可以简写为以下形式:复制代码 代码如下:
 public static int GetNextNumber3(int[] iNumList) { for (int i = 0, j = 1; j < iNumList.Length - 1; i++, j++) { //如果出现断号,则补齐断号 if ((iNumList[j] - iNumList[i]) > 1) { return iNumList[i] + 1; } } return iNumList[iNumList.Length - 1] + 1; }
测试代码如下:复制代码 代码如下:
 static void Main(string[] args) { int[] iNums = { 1, 2, 4, 5, 6, 9, 10 }; //删除了数组中的3,7,8,即3,7,8为断号,下次新增时,希望产生的断号为3 System.Console.WriteLine(BreakNumber.GetNextNumber3(iNums)); System.Console.WriteLine(BreakNumber.GetNextNumber(iNums)); }
运行结果如下:   前几天再次接触到这个问题,由于特殊的场景,再用C#反而会增加开发难度,如果想法通过SQL来解决问题:建表及制造数据SQL:复制代码 代码如下:
 CREATE TABLE testTable ( Code int primary key ) INSERT INTO testTable(Code) VALUES (1) INSERT INTO testTable(Code) VALUES (2) INSERT INTO testTable(Code) VALUES (3) INSERT INTO testTable(Code) VALUES (4) INSERT INTO testTable(Code) VALUES (5) INSERT INTO testTable(Code) VALUES (6) INSERT INTO testTable(Code) VALUES (7) INSERT INTO testTable(Code) VALUES (8) INSERT INTO testTable(Code) VALUES (9) INSERT INTO testTable(Code) VALUES (10)
然后再同样删除第3、7、8行的数据,使这三行产生断号: DELETE FROM testTable WHERE Code in (3,7,8) 分析:要产生连号,即是要让Code这一列上连续的,也就是说每每两行之间的Code相差为1 由于Code是从1开始的(从其他数字开始的也是同理计算),即按Code从小到大排序号,Code为1的行应该为第一行,Code为10的行应该在第10行,即Code=行号, 既然这样,预览数据如下: 删除数据前的排号:     删除数据后的排号:  很明显发现,删除数据前,Code=行号,删除后Code不等于等号,而删除数据后的第一行Code不等于行号的数据,即是第一个出现断号的数据,即为我们想要查询的结果。  如是,如果数据库中有断号,则可以用以下语句直接查出断号:    结果立现。  这段代码还存在一个缺陷,即此方法专用来处理有断号的情况,如果不存在断号时,应该返回Max(RowNumber)+1。正确代码应该如下:  至此,我今天要讲的基本结束,此处借用了SQL2005的方法row_number ,其他数据库中也有类似的方法,大家可以自己摸索。  问题完全解决了吗?大家可以发现,以上出现了断号的情况,都是从小开始补号,比如3,7,8同时为断号,则补3。假如有客户要求从大号开始补号(即3,7,8断号时,补8呢),怎么处理?  前面两种通过C#方法操作的就很容易了,这里主要说一下通过SQL处理的方法:    那么再扩展一下,如何查出所有的断号呢?  要实现这个功能,一般想法是将当前Code与上一行的Code进行对比,但由于可能出现连续断号的情况(例如删除了 Code=7、8、9三行)。此时该如何处理呢?  我的解决方法是,假如max(code)等于100,那么我先构造出100行(怎样构造?数据库中随便找个行数大于100的表,select top 100就行了,如果没有行数大于100的表,就联合查询构造出100行吧),再用这一100行的行号分别和code进行对比,如果存在Code<>行号的,即该处为断裂号,示例如下:假设系统中已经存在另一张表A,它的总行数>max(Code),【注:当然,如果不存在这样的表,也可以通过select 的方式构造出来】,查询所有断号的SQL如下:      至此,问题结束,以上代码的优点在于只用一个SQL语句,而不需要用存储过程、用户自定义函数或C#中的循环,就可以解决各种断号问题,当然为了性能方面还可以再做优化,在此不列出。

感谢各位的阅读,以上就是“怎么用一句SQL解决SQL中断号问题”的内容了,经过本文的学习后,相信大家对怎么用一句SQL解决SQL中断号问题这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

您可能感兴趣的文档:

--结束END--

本文标题: 怎么用一句SQL解决SQL中断号问题

本文链接: https://lsjlt.com/news/60886.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么用一句SQL解决SQL中断号问题
    这篇文章主要讲解了“怎么用一句SQL解决SQL中断号问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用一句SQL解决SQL中断号问题”吧!名词解释  ...
    99+
    2024-04-02
  • 一条sql语句所引发的问题怎么解决
    这篇文章主要介绍“一条sql语句所引发的问题怎么解决”,在日常操作中,相信很多人在一条sql语句所引发的问题怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”一条sql语...
    99+
    2023-01-31
    sql
  • mybatis-plus的sql语句打印问题怎么解决
    本篇内容介绍了“mybatis-plus的sql语句打印问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!第一种方式:mybatis...
    99+
    2023-06-30
  • MyBatis怎么解决Update动态SQL逗号的问题
    这篇文章主要介绍“MyBatis怎么解决Update动态SQL逗号的问题”,在日常操作中,相信很多人在MyBatis怎么解决Update动态SQL逗号的问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MyB...
    99+
    2023-06-28
  • sql中判断语句怎么写
    sql 判断语句用于评估条件并执行相应操作,其语法为 if condition then statement1 [else statement2]。条件可以是逻辑表达式、比较表达式或返回...
    99+
    2024-05-07
  • sql死锁问题怎么解决
    本篇内容介绍了“sql死锁问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! --查询锁表信息,...
    99+
    2024-04-02
  • sql挂起问题怎么解决
    SQL挂起问题可能有多种原因,可以尝试以下解决方法:1. 查看数据库的锁定情况,找出哪些操作或事务正在占用资源,然后终止或重启这些操...
    99+
    2023-06-17
    sql挂起 sql
  • 解读SQL语句中要不要加单引号的问题
    目录SQL语句中要不要加单引号?SQL不使用引号、使用单引号或双引号的区别加引号和不加引号有什么区别?SQL中的单引号和双引号有区别吗?mysql 参考手册总结SQL语句中要不要加单引号? 犯了一个超级超级蠢的错误,把p...
    99+
    2023-02-07
    SQL语句 SQL语句单引号 SQL单引号
  • 怎么解决SQL中报错ORA-16038问题
    这篇文章主要讲解了“怎么解决SQL中报错ORA-16038问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么解决SQL中报错ORA-16038问题”吧!...
    99+
    2024-04-02
  • mybatis中的动态sql问题怎么解决
    本篇内容主要讲解“mybatis中的动态sql问题怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mybatis中的动态sql问题怎么解决”吧!Mybatis框架的动态SQL技术是一种根据...
    99+
    2023-07-05
  • 怎么进行SQL问题的诊断
    这篇文章将为大家详细讲解有关怎么进行SQL问题的诊断,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 问题 诊断 用户反应有一个员工不能设置他的考勤月历了。...
    99+
    2024-04-02
  • php如何解决sql查询语句中中文的问题
    本文小编为大家详细介绍“php如何解决sql查询语句中中文的问题”,内容详细,步骤清晰,细节处理妥当,希望这篇“php如何解决sql查询语句中中文的问题”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、中文字符的...
    99+
    2023-07-05
  • MyBatis解决Update动态SQL逗号的问题
    目录Update动态SQL逗号问题解决办法Mapper(Update)逗号位置Update动态SQL逗号问题 最做项目遇到以下情况,MyBatis中需要动态拼接Update,由于之前...
    99+
    2024-04-02
  • thinkPHP3.2.3中sql注入漏洞问题怎么解决
    这篇文章主要介绍“thinkPHP3.2.3中sql注入漏洞问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“thinkPHP3.2.3中sql注入漏洞问题怎么解决”文章能帮助大家解决问题。...
    99+
    2023-06-30
  • 怎么用Spt_Values解决SQL中的连续日期问题
    本篇内容主要讲解“怎么用Spt_Values解决SQL中的连续日期问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用Spt_Values解决SQL中的连续...
    99+
    2024-04-02
  • Linq To SQL数据问题怎么解决
    这篇文章主要讲解了“Linq To SQL数据问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linq To SQL数据问题怎么解决”吧! 建一个project 命名为DLinq ...
    99+
    2023-06-17
  • SQL数据冗余问题怎么解决
    在SQL中,数据冗余是指相同的数据存储在多个表中,导致数据冗余。数据冗余会增加数据存储的空间,增加数据更新的复杂性,并且可能导致数据...
    99+
    2023-08-19
    SQL
  • Mybatis的sql注释问题怎么解决
    这篇文章主要介绍“Mybatis的sql注释问题怎么解决”,在日常操作中,相信很多人在Mybatis的sql注释问题怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Mybatis的sql注释问题怎么解决...
    99+
    2023-07-02
  • sql笛卡尔积问题怎么解决
    SQL笛卡尔积问题可以通过使用连接操作符(如INNER JOIN、LEFT JOIN、RIGHT JOIN等)来解决。通过这些连接操...
    99+
    2024-03-06
    sql
  • 怎么使用prepared statement解决SQL注入问题
    使用prepared statement可以有效地防止SQL注入问题。下面是使用prepared statement的一般步骤:1....
    99+
    2023-08-08
    SQL
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作