请看代码: DECLARE @max VARCHAR(max) SET @max='aaa...' --这里有8000个a +'bb' --连接一个varchar常量或变量 SELECT LEN(@max) 别想当然以为它会返回8002,而是8000,select @max也只会得到8000个a,后面两个b没了.我们知道,varchar(max)类型不受字符数限制,但为什么会这样? 这其实与@max的数据类型无关,而是与字符串拼接后得到的数据类型有关,或者说,与字符串常量的数据类型推断有关.在S…
一.查询结果使用,字符串拼接 declare @names nvarchar(1000) declare @ParmDefinition nvarchar(1000) declare @sqltext nvarchar(500) set @sqltext=N'Select @names=isnull(@names + '','' , '''' ) + isnull(列名, '''' ) From 表名' set @ParmDefinition = N'@names nvarchar(1000)…
1. 概述 在SQL语句中经常需要进行字符串拼接,以sqlserver,oracle,mysql三种数据库为例,因为这三种数据库具有代表性. sqlserver: select '123'+'456'; oracle: select '123'||'456' from dual; 或 select concat('123','456') from dual; mysql: select concat('123','456'); 注意:SQL Server中没有concat函数(SQL Serve…
在使用pymysql模块时,在使用字符串拼接的注意事项错误用法1 sql='select * from where id="%d" and name="%s" ' %(id,name) cursor.execute(sql)错误用法2 sql="select  *  from test where id="  +  str(id) + " and name='' +   name cursor.execute(sql)正确用法   sq…
一.sql根据一个以逗号隔开的人员guid类型的ID字符串查出其对应的姓名同样拼接成逗号隔开的字符串: 1.需求:管理员发送通知(通知分为普通通知,奖品订单,调查问卷三种类型)给用户,并且可以查看统计哪些人员查看了,哪些还没有查看. 2.数据库表设计:通知表,人员表,奖品订单表,调查问卷的3个表,用户通知表 3.sql语句查讯已发通知信息: select a.*,e.NoRead,e.AlRead,ToUserName= STUFF(( SELECT ',' + Name FROM Users…
单引号必须成对出现,最外层的单引号表示其内部符号为字符:除最外层以外的单引号,每两个单引号代表一个'字符.加号:+用于字符串之间的连接.字符串常量用四个单引号,例如 ' select * from TABLE where COLUMN = ''汉字'' ' 字符串变量用六个单引号和两个加号,例如 ' select * from TABLE where COLUMN = '''+variable+''' '--------------------- 作者:小树爸爸 来源:CSDN 原文:https…
1.Split    SQL Server 2008 新语法: DECLARE @str VARCHAR(MAX) SET @str = REPLACE(@teeIDs, ',', '''),(''') SET @str = 'SELECT * FROM (VALUES(''' + @str + ''')) AS V(A)' EXEC (@str) 据说这个SQL语法是SQL Server 2008的. SELECT * FROM (VALUES(1),(2),(3)) AS V(A) 配合个临…
) set @s='1,2,3' --法一: --法二: exec('select * from tb where id in ('+@s+')')…
1.top命令查找导致cup爆表的进程 2. top -H -p10832 (10832是Java进程的PID)命令找出了具体的线程 3.使用用命令 jstack 10832> jstack.txt (10832是Java进程的PID)打印出了Java进程的堆栈信息放到jstack.txt文件了: 由于堆栈打印的线程的native id是十六机制的,所以,我把十进制的线程id(6904.6905.6906.6907)转化成十六进制(0x1af8.0x1af9.0x1afa.0x1afb):最后,…
今天遇到了一个奇葩的问题:存储过程中的sql字符串拼接的太长,超出了分页存储过程执行sql参数的nvarchar(4000)的长度. 没办法,只能修改自己的存储过程,因为分页存储过程是不能动的. 开始想到的方法是将里层的select语句抽出来,用exec(strInnerSql)执行,将查询胡来的数据放到临时表中,在@s中用临时表获取数据,结果以时报告终 错误原因:执行@s语句的时候找不到执行exec(strInnerSql)产生的临时表 好郁闷啊,怎么会这样呢,明明在一个存储过程中执行的,怎么…