1. --需求说明:
  2. /*
  3. id         col
  4. ---------- ----------
  5. AB00001    a
  6. AB00002    b
  7. --当再插入数据的时候让id自动变成AB00003
  8. */
  9. --1.求最大值法(高并发时不适用,只是介绍个思路)
  10. --测试数据
  11. if object_id('[macotb]') is not null
  12. drop table [macotb]
  13. create table [macotb] (id varchar(7),col varchar(1))
  14. insert into [macotb]
  15. select 'AB00001','a' union all
  16. select 'AB00002','b'
  17. declare @max varchar(7)
  18. select @max='AB'+right('00000'+ltrim(max(replace(id,'AB','')+1)),5) from [macotb]
  19. insert into [macotb] select @max,'c'
  20. select * from [macotb]
  21. /*
  22. id      col
  23. ------- ----
  24. AB00001 a
  25. AB00002 b
  26. AB00003 c
  27. */
  28. --2.利用@@identity,分步处理
  29. if object_id('[macotb]') is not null
  30. drop table [macotb]
  31. create table [macotb] ([no] int identity,id varchar(7),col varchar(1))
  32. insert into [macotb]
  33. select 'AB00001','a' union all
  34. select 'AB00002','b'
  35. insert into [macotb](col) select 'c'
  36. update [macotb]
  37. set id='AB'+right('00000'+ltrim([no]),5) where [no]=@@identity
  38. select id,col from [macotb]
  39. /*
  40. id      col
  41. ------- ----
  42. AB00001 a
  43. AB00002 b
  44. AB00003 c
  45. */
  46. --3.直接添加运算列
  47. if object_id('[macotb]') is not null
  48. drop table [macotb]
  49. create table [macotb]
  50. (
  51. [no] int identity,
  52. id as ('AB'+right('00000'+ltrim([no]),5)),
  53. col varchar(1)
  54. )
  55. insert into [macotb](col) select 'a' union all select 'b'
  56. select id,col from [macotb]
  57. /*
  58. id           col
  59. ------------ ----
  60. AB00001      a
  61. AB00002      b
  62. */
  63. insert into [macotb](col) select 'c' union all select 'd'
  64. select id,col from [macotb]
  65. /*
  66. id           col
  67. ------------ ----
  68. AB00001      a
  69. AB00002      b
  70. AB00003      c
  71. AB00004      d
  72. */
  73. --叶子建议使用第三种方式!

SQL SERVER 如何处理带字母的自增列--【叶子】的更多相关文章

  1. SQL Server FOR XML PATH 语句的应用---列转行

    经常在论坛看到高手使用了 for xml path,由于是搜索一下,记录了详细的使用方法.在SQL Server中利用 FOR XML PATH 语句能够把查询的数据生成XML数据,下面是它的一些应用 ...

  2. SQL Server分区表,能否按照多个列作为分区函数的分区依据(转载)

    问: Hi, I have a table workcachedetail with 40 million rows which has 8 columns.We decided to partiti ...

  3. Sql Server插入数据并返回自增ID,@@IDENTITY,SCOPE_IDENTITY和IDENT_CURRENT的区别

    预备知识:SQLServer的IDENTITY关键字IDENTITY关键字代表的是一个函数,而不是identity属性.在access里边没有这个函数,所以在access不能用这个语句.语法:iden ...

  4. Sql Server插入数据并返回自增ID,@@IDENTITY,SCOPE_IDENTITY和IDENT_CURRENT的区别(转载)

    预备知识:SQL Server的IDENTITY关键字IDENTITY关键字代表的是一个函数,而不是identity属性.在access里边没有这个函数,所以在access不能用这个语句.语法:ide ...

  5. SQL Server事务回滚对自增键的影响

    SQL Server事务回滚时是删除原先插入导致的自增值,也就是回滚之前你你插入一条数据导致自增键加1,回滚之后还是加1的状态 --如果获取当前操作最后插入的identity列的值:select @@ ...

  6. SQL SERVER 自带系统存储过程分类

    目录存储过程 用于实现 ODBC 数据字典功能,并隔离 ODBC 应用程序以使其不受基础系统表更改的影响. 变更数据捕获存储过程 用于启用.禁用.或报告变更数据捕获对象. 游标存储过程 用于实现游标变 ...

  7. Sql Server-使用Sql Server自带的分词功能实现字段关键词提取(分词能力很低,慎用)

    “创建全文索引 启动服务 在SQL Server配置管理工具中,找到'SQL Full-text Filter Daemon Launcher'服务用本地用户启动. 创建全文目录 打开需要创建全文目录 ...

  8. SQL Server 创建表 添加主键 添加列常用SQL语句

    --删除主键 alter table 表名 drop constraint 主键名 --添加主键 alter table 表名 add constraint 主键名 primary key(字段名1, ...

  9. SQL Server 创建表 添加主键 添加列常用SQL语句【转】

    --删除主键alter table 表名 drop constraint 主键名--添加主键alter table 表名 add constraint 主键名 primary key(字段名1,字段名 ...

随机推荐

  1. Gym 101128F Sheldon Numbers(网络流)

    [题目链接] http://codeforces.com/gym/101128/attachments [题目大意] 给出一张地图,分为高地和低地,高低地的交界线上划有红线, 现在要开小车跨过每条红线 ...

  2. 【贪心】AtCoder Regular Contest 079 E - Decrease (Judge ver.)

    每次将最大的数减到n以下,如此循环直到符合题意. 复杂度大概是n*n*log?(?). #include<cstdio> #include<iostream> #include ...

  3. springmvc之文件上传、下载

    1.接收到的是图片的流时 //上传头像 @RequestMapping(value = "/uploadHeadSculpture", method = RequestMethod ...

  4. [POJ3581]Sequence

    [POJ3581]Sequence 题目大意: 给定序列\(A_{1\sim n}\),其中\(A_1\)为最大的数.要把这个序列分成\(3\)个非空段,并将每一段分别反转,求能得到的字典序最小的序列 ...

  5. I/O多路复用机制:epoll

    在过去的linux 网络编程中,采用select来做事件触发,其缺点在于每次调用select,都需要把fd集合拷贝到内核,内核必须遍历传递进来的所有fd,这在fd很多时开销会很大,相比于select, ...

  6. ie8以下浏览器注意事项

    ie8以下ajax请求或者socket请求时一定要加二级域名:(目的不能垮域访问)

  7. [转]spring property标签中的 ref属性和ref 标签有什么不同

    spring property标签中的 ref属性和ref 标签有什么不同? 如下:<property name="a" ref="b" /> sp ...

  8. php分布式缓存系统 Memcached 入门

    Memcached 是一个分布式的缓存系统, 但是 Memcachd 到底是什么意思,有什么作用呢?缓存一般用来保存一些经常被存取的数据和资源(例如:浏览器会将访问过的网页会话缓存起来),因为通过缓存 ...

  9. HttpClient中文乱码问题排查

    可以尝试一下方法解决: 1. httpPost.setHeader("Content-Type", "application/json; charset=UTF-8&qu ...

  10. Java构造和解析Json数据的两种方法详解一——json-lib

    转自:http://www.cnblogs.com/lanxuezaipiao/archive/2013/05/23/3096001.html 在www.json.org上公布了很多JAVA下的jso ...