数据库查询语句,如何排除有数字的名称

比如名称有的是abcd123,abcd356,我想要排除后面的数字的查询,nolike'%[0-9]'这里的【0-9】是我写的,不能用,这里要用什么代表所有不规则的数字呢... 比如名称有的是abcd123,abcd356,我想要排除后面的数字的查询, no like '%[0-9]'
这里的【0-9】是我写的,不能用,这里要用什么代表所有不规则的数字呢。
like '%[^0-9]' 只是sql查询语句而已,mysql数据库的,我要查询的是尾数不能是数字的。not like '%[0-9]'这样查出来确全部显示出来
到底是什么问题呢
展开
 我来答
百度网友66464e57e
2012-06-19 · 超过26用户采纳过TA的回答
知道答主
回答量:49
采纳率:0%
帮助的人:61.8万
展开全部
如果是SQLSERVER Or Access
select * from tab where isnumeric(name)<>0

如果ORACLE ,由于Oracle没有自带的判断数字的函数,需要自创建函数isnumeric
 CREATE OR REPLACE FUNCTION isnumeric (str IN VARCHAR2)
  RETURN NUMBER
  IS
  v_str FLOAT;
  BEGIN
  IF str IS NULL
  THEN
  RETURN 0;
  ELSE
  BEGIN
  SELECT TO_NUMBER (str)
  INTO v_str
  FROM DUAL;
  EXCEPTION
  WHEN INVALID_NUMBER
  THEN
  RETURN 0;
  END;
  RETURN 1;
  END IF;
  END isnumeric;
用法:
select * from tab where isnumeric(name)<>0
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式