Postgresql: Extract text before number starts
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ height:90px;width:728px;box-sizing:border-box;
}
I have a table os
which contains below data
id name
-- ----
1 windows server 2012 R2
2 windows 2016 SQL
3 Oracle linux 7.5
I need to update os table to something like below
id name
-- ----
1 windows server
2 windows
3 Oracle linux
Basically I need to extract the text from name starting from to before the number.
I am not getting an idea about how to do this. How can I do this in a Postgresql query?
postgresql
add a comment |
I have a table os
which contains below data
id name
-- ----
1 windows server 2012 R2
2 windows 2016 SQL
3 Oracle linux 7.5
I need to update os table to something like below
id name
-- ----
1 windows server
2 windows
3 Oracle linux
Basically I need to extract the text from name starting from to before the number.
I am not getting an idea about how to do this. How can I do this in a Postgresql query?
postgresql
add a comment |
I have a table os
which contains below data
id name
-- ----
1 windows server 2012 R2
2 windows 2016 SQL
3 Oracle linux 7.5
I need to update os table to something like below
id name
-- ----
1 windows server
2 windows
3 Oracle linux
Basically I need to extract the text from name starting from to before the number.
I am not getting an idea about how to do this. How can I do this in a Postgresql query?
postgresql
I have a table os
which contains below data
id name
-- ----
1 windows server 2012 R2
2 windows 2016 SQL
3 Oracle linux 7.5
I need to update os table to something like below
id name
-- ----
1 windows server
2 windows
3 Oracle linux
Basically I need to extract the text from name starting from to before the number.
I am not getting an idea about how to do this. How can I do this in a Postgresql query?
postgresql
postgresql
edited Nov 23 '18 at 17:26
halfer
14.8k759117
14.8k759117
asked Nov 22 '18 at 8:32
Hemadri DasariHemadri Dasari
10.4k32358
10.4k32358
add a comment |
add a comment |
3 Answers
3
active
oldest
votes
You may try this. It starts from beginning and finds anything that's not a digit before a digit and replaces it with the matched string.
SELECT s,RTRIM(regexp_replace (s, '^([^d]+)d(.*)$', '1')) as m
FROM ( VALUES ('windows server 2012 R2'),
('windows 2016 SQL'),
('Oracle linux 7.5' ) ) AS t(s);
s | m
------------------------+----------------
windows server 2012 R2 | windows server
windows 2016 SQL | windows
Oracle linux 7.5 | Oracle linux
(3 rows)
add a comment |
The function substring
allows to specify regular expression:
So some solution can looks like:
postgres=# select name, trim(substring(name from '[^d]+')) from the_table;
+----------------------------+----------------+
| name | btrim |
+----------------------------+----------------+
| windows server 2012 R2 foo | windows server |
| windows 2016 SQL | windows |
| Oracle linux 7.5 | Oracle linux |
+----------------------------+----------------+
(3 rows)
More in documentation
add a comment |
This is a case where the absence of a function that finds a string based on a regex is a bit cumbersome.
You can use regexp_matches()
to find the first pattern of the first number in the string, then combine that with substr()
and strpos()` to extract everything before that:
select id, substr(name, 1, strpos(name, (regexp_matches(name, '[0-9.]+'))[1]) - 1)
from the_table;
regexp_matches()
returns an array of all matches. So wee need to extract the first first match from that array. That's what (regexp_matches(name, '[0-9.]+'))[1]
does.
Online example: https://rextester.com/BIOV86746
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53426743%2fpostgresql-extract-text-before-number-starts%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
3 Answers
3
active
oldest
votes
3 Answers
3
active
oldest
votes
active
oldest
votes
active
oldest
votes
You may try this. It starts from beginning and finds anything that's not a digit before a digit and replaces it with the matched string.
SELECT s,RTRIM(regexp_replace (s, '^([^d]+)d(.*)$', '1')) as m
FROM ( VALUES ('windows server 2012 R2'),
('windows 2016 SQL'),
('Oracle linux 7.5' ) ) AS t(s);
s | m
------------------------+----------------
windows server 2012 R2 | windows server
windows 2016 SQL | windows
Oracle linux 7.5 | Oracle linux
(3 rows)
add a comment |
You may try this. It starts from beginning and finds anything that's not a digit before a digit and replaces it with the matched string.
SELECT s,RTRIM(regexp_replace (s, '^([^d]+)d(.*)$', '1')) as m
FROM ( VALUES ('windows server 2012 R2'),
('windows 2016 SQL'),
('Oracle linux 7.5' ) ) AS t(s);
s | m
------------------------+----------------
windows server 2012 R2 | windows server
windows 2016 SQL | windows
Oracle linux 7.5 | Oracle linux
(3 rows)
add a comment |
You may try this. It starts from beginning and finds anything that's not a digit before a digit and replaces it with the matched string.
SELECT s,RTRIM(regexp_replace (s, '^([^d]+)d(.*)$', '1')) as m
FROM ( VALUES ('windows server 2012 R2'),
('windows 2016 SQL'),
('Oracle linux 7.5' ) ) AS t(s);
s | m
------------------------+----------------
windows server 2012 R2 | windows server
windows 2016 SQL | windows
Oracle linux 7.5 | Oracle linux
(3 rows)
You may try this. It starts from beginning and finds anything that's not a digit before a digit and replaces it with the matched string.
SELECT s,RTRIM(regexp_replace (s, '^([^d]+)d(.*)$', '1')) as m
FROM ( VALUES ('windows server 2012 R2'),
('windows 2016 SQL'),
('Oracle linux 7.5' ) ) AS t(s);
s | m
------------------------+----------------
windows server 2012 R2 | windows server
windows 2016 SQL | windows
Oracle linux 7.5 | Oracle linux
(3 rows)
answered Nov 22 '18 at 9:51
Kaushik NayakKaushik Nayak
21.9k41332
21.9k41332
add a comment |
add a comment |
The function substring
allows to specify regular expression:
So some solution can looks like:
postgres=# select name, trim(substring(name from '[^d]+')) from the_table;
+----------------------------+----------------+
| name | btrim |
+----------------------------+----------------+
| windows server 2012 R2 foo | windows server |
| windows 2016 SQL | windows |
| Oracle linux 7.5 | Oracle linux |
+----------------------------+----------------+
(3 rows)
More in documentation
add a comment |
The function substring
allows to specify regular expression:
So some solution can looks like:
postgres=# select name, trim(substring(name from '[^d]+')) from the_table;
+----------------------------+----------------+
| name | btrim |
+----------------------------+----------------+
| windows server 2012 R2 foo | windows server |
| windows 2016 SQL | windows |
| Oracle linux 7.5 | Oracle linux |
+----------------------------+----------------+
(3 rows)
More in documentation
add a comment |
The function substring
allows to specify regular expression:
So some solution can looks like:
postgres=# select name, trim(substring(name from '[^d]+')) from the_table;
+----------------------------+----------------+
| name | btrim |
+----------------------------+----------------+
| windows server 2012 R2 foo | windows server |
| windows 2016 SQL | windows |
| Oracle linux 7.5 | Oracle linux |
+----------------------------+----------------+
(3 rows)
More in documentation
The function substring
allows to specify regular expression:
So some solution can looks like:
postgres=# select name, trim(substring(name from '[^d]+')) from the_table;
+----------------------------+----------------+
| name | btrim |
+----------------------------+----------------+
| windows server 2012 R2 foo | windows server |
| windows 2016 SQL | windows |
| Oracle linux 7.5 | Oracle linux |
+----------------------------+----------------+
(3 rows)
More in documentation
answered Nov 22 '18 at 10:07
Pavel StehulePavel Stehule
23.6k34859
23.6k34859
add a comment |
add a comment |
This is a case where the absence of a function that finds a string based on a regex is a bit cumbersome.
You can use regexp_matches()
to find the first pattern of the first number in the string, then combine that with substr()
and strpos()` to extract everything before that:
select id, substr(name, 1, strpos(name, (regexp_matches(name, '[0-9.]+'))[1]) - 1)
from the_table;
regexp_matches()
returns an array of all matches. So wee need to extract the first first match from that array. That's what (regexp_matches(name, '[0-9.]+'))[1]
does.
Online example: https://rextester.com/BIOV86746
add a comment |
This is a case where the absence of a function that finds a string based on a regex is a bit cumbersome.
You can use regexp_matches()
to find the first pattern of the first number in the string, then combine that with substr()
and strpos()` to extract everything before that:
select id, substr(name, 1, strpos(name, (regexp_matches(name, '[0-9.]+'))[1]) - 1)
from the_table;
regexp_matches()
returns an array of all matches. So wee need to extract the first first match from that array. That's what (regexp_matches(name, '[0-9.]+'))[1]
does.
Online example: https://rextester.com/BIOV86746
add a comment |
This is a case where the absence of a function that finds a string based on a regex is a bit cumbersome.
You can use regexp_matches()
to find the first pattern of the first number in the string, then combine that with substr()
and strpos()` to extract everything before that:
select id, substr(name, 1, strpos(name, (regexp_matches(name, '[0-9.]+'))[1]) - 1)
from the_table;
regexp_matches()
returns an array of all matches. So wee need to extract the first first match from that array. That's what (regexp_matches(name, '[0-9.]+'))[1]
does.
Online example: https://rextester.com/BIOV86746
This is a case where the absence of a function that finds a string based on a regex is a bit cumbersome.
You can use regexp_matches()
to find the first pattern of the first number in the string, then combine that with substr()
and strpos()` to extract everything before that:
select id, substr(name, 1, strpos(name, (regexp_matches(name, '[0-9.]+'))[1]) - 1)
from the_table;
regexp_matches()
returns an array of all matches. So wee need to extract the first first match from that array. That's what (regexp_matches(name, '[0-9.]+'))[1]
does.
Online example: https://rextester.com/BIOV86746
answered Nov 22 '18 at 9:50
a_horse_with_no_namea_horse_with_no_name
308k46471573
308k46471573
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53426743%2fpostgresql-extract-text-before-number-starts%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown