当前位置: 首页 > 图文教程 > 数据库 > MSSQL > SQLServer 设置单词首字母大写

MSSQL
SQL语言快速入门之三
Sql连接查询
Sql联合查询
精通数据库系列之入门-基础篇1
精通数据库系列之入门-基础篇2
精通数据库系列之入门-基础篇3
精通数据库系列之入门-技巧篇1
SQL语言快速入门之一
SQL语言快速入门之二
优化Oracle库表设计的若干方法
Oracle数据库取消8080端口占用
MS SQL SERVER 图像或大文本的输入输出
SQL Server 2000之日志传送功能 - 描述
SQL Server 2000之日志传送功能-设定
SQL Server 2000之日志传送功能—问题解决
使用JMail组件代替Sql Mail发送Email
SQL中通配符、转义符与[号的使用(downmoon)
如何在Oracle10g中启动和关闭OEM
如何快速杀死占用过多资源(CPU,内存)的数据库进程
在SQL Server 2000里设置和使用数据库复制

MSSQL 中的 SQLServer 设置单词首字母大写


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 250 ::
收藏到网摘: n/a

能实现效果的方法有很多种,这里借用Js的正则表达式来处理.
复制代码 代码如下:

/*
--SQLServer中将字符串首字母设置大写:
--作者:jinjazz /csdn
--SQLServer2005启用OLEAutomation
sp_configure 'show advanced options', 1;
go
RECONFIGURE;
go
sp_configure 'Ole Automation Procedures', 1;
go
RECONFIGURE;
go
*/
use tempdb
go
if (object_id ('fn_toTitleCase' ) is not null )
drop function dbo . fn_toTitleCase
go
create function fn_toTitleCase (@inStr varchar (8000 ))
returns varchar (8000 )
as
begin
declare @str varchar (8000 )
set @str = 'var data = "' +@inStr + '";
var reg = /\b(\w)|\s(\w)/g ;
data = data.toLowerCase();
data.replace(reg,function(m){return m.toUpperCase()});'
declare @object int
declare @r varchar (800 )
exec sp_OACreate 'MSScriptControl.ScriptControl' ,@object output
exec sp_OASetProperty @object , 'Language' , 'javascript'
exec sp_OAMethod @object , 'eval' , @r out , @str
return @r
end
go
select dbo. fn_toTitleCase ('create function fn_toTitleCase(@inStr varchar(8000)) returns varchar(8000)' )
/*输出
Create Function Fn_totitlecase(@Instr Varchar(8000)) Returns Varchar(8000)
*/