substring和exec注意点

substring(start,end) 包左不包右   

实例:将网址http://211.137.199.131/ 去掉前缀http://    用substring(7,length-1)         注意这里不是substring(6,length-2)


exec正则匹配出来的是一个数组a,其中a[0]表示匹配出来的完整字符串,a[1]是正则表达式中前面一截,a[2]是后面一截。

       实例:var reg =/(\b1344\d+|\b1574\d+)\s+(\S+)/gi;

           var a = reg.exec(content);

                  a[1]是(\b1344\d+|\b1574\d+)\s

                  a[2]是(\S+)


使用exec时不能用正则表达式直接.exec方法,需要用变量代替正则表达式,否则不会记录exec的索引,因为正则表达式调用exec相当于重新声明一个变量,地址会改变,所以不会记录索引。如下例,上面这个是对的,下面这个匹配的结果头两条会是重复的。

         实例:var reg=/GigabitEthernet\d\/\d\/\d/g;
         var r=reg.exec(res);
         var result="";
         while(r){
    result=result+","+r[0];
    r=reg.exec(res);
         } 
      


          var r=/GigabitEthernet\d\/\d\/\d/g.exec(res);
          var result="";
          while(r){
     result=result+","+r[0];
     r=/GigabitEthernet\d\/\d\/\d/g.exec(res);
          } 
      

  

   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
--#建立存储过程,把数据导入到相应的表中 --execute add_data '面向对象系统分析与设计实验信计201','面向对象系统分析与设计实验信计201','101001' create proc add_data @course_id varchar(200),@table_name varchar(200),@teacher_id varchar(200) as if exists(select * from syscursors where cursor_name='prj_Cursor') deallocate prj_Cursor declare @str_sql varchar(1024); declare @num int; SELECT @num=count(NAME)-3 FROM SYSCOLUMNS WHERE ID=OBJECT_ID(@table_name); set @str_sql=CONCAT('insert into tb_Course(course_id,course_name,num_of_project,table_name,teacher_id)values(', '''', @course_id, ''',', '''', left(@course_id,len(@course_id)-3), ''',', cast(@num as varchar), ',''', @table_name, ''',''', @teacher_id, ''')'); print @str_sql EXEC(@str_sql)--课程信息插入到tb_Course DECLARE prj_Cursor SCROLL CURSOR for SELECT NAME FROM sys.columns WHERE [object_id]=OBJECT_ID(@table_name) order by column_id; OPEN prj_Cursor declare @prj varchar(128) FETCH ABSOLUTE 4 FROM prj_Cursor into @prj while (@@fetch_status=0) begin--把实验项目加入到tb_Project表 print(@prj) set @str_sql='insert into tb_Project(project_id,project_name,course_id,project_open) values('''+ right(@course_id,3)+@prj+''','+ ''''+@prj+''','''+@course_id+''','+'0'+')' print @str_sql EXEC(@str_sql)--项目信息插入到tb_Project FETCH next FROM prj_Cursor into @prj end set @str_sql=CONCAT('insert into tb_User(user_name,user_password,full_name) select ', 'SNO', ',substring(sys.fn_sqlvarbasetostr(HASHBYTES(''MD5'',','SNO)),3,32),Sname', ' from ', @table_name, ' where SNO not in(select user_name from tb_User)' ); --如果字段的类型是nvarchar的,md5加密前需要强制转化一下类型CAST([SNO] as varchar(50)) print @str_sql EXEC(@str_sql)--学生账号插入到tb_User set @str_sql='insert into tb_SC(SNO,course_id) select SNO,''' +@course_id+ ''' from '+@table_name print @str_sql EXEC(@str_sql)--选课信息插入到tb_SC go 怎么分段写入SQL
05-24

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值