用一条SQL语句查询出所有员工姓名的字母前三位

用一条SQL语句查询出所有员工姓名的字母前三位... 用一条SQL语句查询出所有员工姓名的字母前三位 展开
 我来答
养时芳呼诗
2020-02-03 · TA获得超过3.6万个赞
知道大有可为答主
回答量:1.4万
采纳率:26%
帮助的人:817万
展开全部
sql中按姓名拼音排序

select
isnull(b.py,upper(left(a.username,1)))
as
py
,a.username
from
(
select
'a3'
as
username
union
select
username
from
usertable
--修改这里的姓名列~
)
a
left
outer
join
(
select
'a'
as
py,n'骜'
as
word,
n'啊'
as
sword
union
select
'b',n'簿',n'骜'
union
select
'c',n'错',n'簿'
union
select
'd',n'鵽',n'错'
union
select
'e',n'樲',n'鵽'
union
select
'f',n'鳆',n'樲'
union
select
'g',n'腂',n'鳆'
union
select
'h',n'夻',n'腂'
union
select
'j',n'攈',n'夻'
union
select
'k',n'穒',n'攈'
union
select
'l',n'鱳',n'穒'
union
select
'm',n'旀',n'鱳'
union
select
'n',n'桛',n'旀'
union
select
'o',n'沤',n'桛'
union
select
'p',n'曝',n'沤'
union
select
'q',n'囕',n'曝'
union
select
'r',n'鶸',n'囕'
union
select
's',n'蜶',n'鶸'
union
select
't',n'箨',n'蜶'
union
select
'w',n'鹜',n'箨'
union
select
'x',n'鑂',n'鹜'
union
select
'y',n'韵',n'鑂'
union
select
'z',n'咗',n'韵'
)
b
on
left(username,1)
between
b.sword
and
b.word
where
username<>'a3'
and
py='a'
--这里的and
py='a'是查询以a拼音开头的姓名,你可以
改成其他的,或者直接去掉就是查询所有的~
order
by
py
kyklyll12
2010-01-18 · 超过16用户采纳过TA的回答
知道答主
回答量:36
采纳率:0%
帮助的人:0
展开全部
方法一. left从左往右数
select left(员工姓名,3),员工姓名 from 员工
方法二. 截取字符
select substring(员工姓名,0,4),员工姓名from 员工
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2010-01-18
展开全部
楼上2位已经综合了 ORACLE 和 SQL SERVER的 答案了,呵呵。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wangyanjj
2010-01-18 · TA获得超过143个赞
知道小有建树答主
回答量:342
采纳率:0%
帮助的人:239万
展开全部
oracle环境

select substr(员工姓名,1,3) from 员工;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友9ef78f420
2010-01-18 · TA获得超过103个赞
知道答主
回答量:46
采纳率:0%
帮助的人:40万
展开全部
员工姓名长啥样儿啊,是字母么?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式