SQLSERVER 执行函数

小鸟向前飞 2011-11-14 03:09:08
从网上找了个函数


if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[f_convert]') and xtype in (N'FN', N'IF', N'TF'))
drop function [dbo].[f_convert]
GO

/*--全角/半角转换

转换说明
全角字符从的unicode编码从65281~65374
半角字符从的unicode编码从 33~126
空格比较特殊,全角为 12288,半角为 32
而且除空格外,全角/半角按unicode编码排序在顺序上是对应的
所以可以直接通过用+-法来处理非空格数据,对空格单独处理
like的时候,指定排序规则 COLLATE Latin1_General_BIN
是保证字符顺序按unicode编码排序


declare @s1 varchar(8000)
select @s1='中  2-3456a78STUVabn中国opwxyz'
select dbo.f_convert(@s1,0),dbo.f_convert(@s1,1)
*/
Create FUNCTION f_Convert(
@str NVARCHAR(4000), --要转换的字符串
@flag bit --转换标志,0转换成半角,1转换成全角
)RETURNS nvarchar(4000)
AS
BEGIN
DECLARE
@pat nvarchar(8),
@step int,
@i int,
@spc int
IF @flag=0
Select @pat=N'%[!-~]%',@step=-65248,
@str=REPLACE(@str,N' ',N' ')
ELSE
Select @pat=N'%[!-~]%',@step=65248,
@str=REPLACE(@str,N' ',N' ')
SET @i=PATINDEX(@pat COLLATE LATIN1_GENERAL_BIN,@str)
WHILE @i>0
Select @str=REPLACE(@str,
SUBSTRING(@str,@i,1),
NCHAR(UNICODE(SUBSTRING(@str,@i,1))+@step))
,@i=PATINDEX(@pat COLLATE LATIN1_GENERAL_BIN,@str)
RETURN(@str)
END
GO

declare @s1 varchar(8000)
set @s1='中  2-3456a78STUVabn中国opwxyz'
select dbo.f_Convert(@s1,0),dbo.f_Convert(@s1,1)



为什么在数据库里无法执行 报错信息如下:

消息 4121,级别 16,状态 1,第 3 行
找不到列 "dbo" 或用户定义的函数或聚合 "dbo.f_Convert",或者名称不明确。

双节提示信息 定位到 select dbo.f_Convert(@s1,0),dbo.f_Convert(@s1,1) 这一行
...全文
841 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
快溜 2011-11-14
  • 打赏
  • 举报
回复
实在不知道就去数据库里找函数--编写函数脚本--create到新的。。。自己看看
快溜 2011-11-14
  • 打赏
  • 举报
回复
[ad0039999].[f_Convert]
小鸟向前飞 2011-11-14
  • 打赏
  • 举报
回复
写上架构名 还是报错


消息 4121,级别 16,状态 1,第 3 行
找不到列 "ad0039999" 或用户定义的函数或聚合 "ad0039999.f_Convert",或者名称不明确。
快溜 2011-11-14
  • 打赏
  • 举报
回复
右键安全性--登录名--属性--用户映射
--小F-- 2011-11-14
  • 打赏
  • 举报
回复
dbo.f_Convert

DBO是架构名 后面的f_Convert是函数名

如果架构不是DBO 你的就错误了
中国风 2011-11-14
  • 打赏
  • 举报
回复
沒有創建到這個函數?

檢查用戶名權限
小鸟向前飞 2011-11-14
  • 打赏
  • 举报
回复
你用什么登录的?
水族杰纶 2011-11-14
  • 打赏
  • 举报
回复
看下这个函数所属的架构是什么
小鸟向前飞 2011-11-14
  • 打赏
  • 举报
回复
这……
pengxuan 2011-11-14
  • 打赏
  • 举报
回复
我这里不报错啊

34,588

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧