Sqlserver
 sql >> база данни >  >> RDS >> Sqlserver

Как да обърнете низ (SQL Server 2005, SET BASED)

Редактиране Първоначалният отговор не е разбрал изискването. Намерих поправка, но разделянето до ниво персонаж вече е напълно ненужно. Поне може да даде някои идеи!

WITH Strings AS
(
select 'A Student' as String
UNION ALL
select 'blah' as String
UNION ALL
select 'the quick brown fox jumped over the lazy dog' as String
),
SplitChars As
(
SELECT ROW_NUMBER() OVER (ORDER BY number) AS number, String, SUBSTRING(String,number,1) AS Ch FROM Strings
JOIN master.dbo.spt_values on number BETWEEN 1 AND LEN(String) AND type='P'
)


SELECT String,
replace(Stuff(
            (
            Select '' + Ch
            From SplitChars SC3
            WHERE SC3.String = SC.String
            Order By (SELECT COUNT(*) FROM SplitChars SC2 WHERE SC2.String = SC3.String AND SC2.Ch = ' ' AND SC2.number < SC3.number) desc, case when SC3.ch = ' ' then -1 else number end
            For Xml Path('')
            ),1, 0, ''), '&#x20;', ' ') AS Reversed
FROM SplitChars SC 
GROUP BY String

Връщане

  • Студент А
  • бла
  • куче мързеливо скочилата лисица кафяво бързо


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SQL Server:Pivot с потребителски имена на колони

  2. SQL Брой за включване на нулеви стойности

  3. Ограничения на паметта в SQL Server 2016 SP1

  4. Как ефективно моделирате наследяването в база данни?

  5. поръчка чрез newid() - как работи?