Apostrophe Problem

SpartanAOD

New Member
Joined
Sep 15, 2016
Messages
25
How do I make this formula work for people with apostrophes in their names, like O'Connor?

=DLookUp("[Current Wage]","On-Call Wages","[Employee]='" & [Forms]![On-Call Records]![Name] & "'")
 

Excel Facts

How to total the visible cells?
From the first blank cell below a filtered data set, press Alt+=. Instead of SUM, you will get SUBTOTAL(9,)
.
Here is a resource hat might help : https://stackoverflow.com/questions...-access-vba-when-the-field-has-a-single-quote

Another suggestion ... for your purposes, why not change the O'Connor ... to ... OConner ?

I won't be the only one entering data into this database, so I don't want to risk someone forgetting about that rule. Plus, I might have to compare records to other spreadsheets that use the ' in the name.

I'm not sure on how to apply the info in your link. This seems like a major oversight by the folks who created SQL
 
Upvote 0
something like this maybe

Code:
dim temp_string as string 


' replace a single quote with two single quotes 
' yes, its difficult to see 
' but we have double quote single quote double quote 
' and then we have double quote single quote single quote double quote 
temp_string = Replace(  [Forms]![On-Call Records]![Name], "'", "''", 1, , vbTextCompare)


=DLookUp("[Current Wage]","On-Call Wages","[Employee]='" & temp_string & "'")


its not really an oversight by the creators of SQL
its just a limitation of the alphabet

you know that when you use
like
you use an asterisk

example:
select some columns from some table where name like 'jackie*'

but when do you do if the name actually contains a * ?

and in many languages \n means print a new line
and \t means print a tab

but what if you actually want to print \n or \t ?

then you have to do \\n or \\t

and don't even think about regular expressions
there are so many characters with special meaning
regular expressions are so powerful and so useful -- and so freaking difficult LOL
 
Upvote 0
If you have names with single quotes you can use this formula:
DLookUp("[Current Wage]","On-Call Wages","[Employee]='" & Replace([Forms]![On-Call Records]![Name],"'","''") & "'")

The the resulting where clause is 'O''Connor', which is the correct way to use a literal string containing a single quote inside of it.

Not sure if that would work if the name had two single quotes in a row, a single quote at the beginning, or a single quote at the end (i.e., ''OConnor, O''Connor, or OConnor'' are all possible failures). I don't think that's a problem.

Nearly all programming languages use a double or single quote to enclose literal strings, and for those that do they all require what is called an escape character to allow for a double or single quote to appear inside a string. So, this wasn't an oversight but simply a common limitation of manipulating raw strings in a programming language that uses a single quotes (or double quotes) to delimit strings. As you see from the previous post, it comes up in syntax for other uses as well, not only for raw strings.

For what it's worth, whenever possible database designers will use employee ID or employee number for lookups, rather than the actual employee name, to avoid problems exactly like this (as well as improve efficiency in large databases, and, most importantly, solve headaches when for example an employee's name changes after a major life event such as marriage or divorce).

Speaking of this, I recently read that Wozniak was employee number 1 at Apple and Job was employee number 2, which made Jobs upset since he wanted to be number one. So he took employee number 0 instead! But the payroll system required a positive integer for employee number, so it didn't really work after all.
 
Last edited:
Upvote 0
If you have names with single quotes you can use this formula:
DLookUp("[Current Wage]","On-Call Wages","[Employee]='" & Replace([Forms]![On-Call Records]![Name],"'","''") & "'")

The the resulting where clause is 'O''Connor', which is the correct way to use a literal string containing a single quote inside of it.

Not sure if that would work if the name had two single quotes in a row, a single quote at the beginning, or a single quote at the end (i.e., ''OConnor, O''Connor, or OConnor'' are all possible failures). I don't think that's a problem.

Nearly all programming languages use a double or single quote to enclose literal strings, and for those that do they all require what is called an escape character to allow for a double or single quote to appear inside a string. So, this wasn't an oversight but simply a common limitation of manipulating raw strings in a programming language that uses a single quotes (or double quotes) to delimit strings. As you see from the previous post, it comes up in syntax for other uses as well, not only for raw strings.

For what it's worth, whenever possible database designers will use employee ID or employee number for lookups, rather than the actual employee name, to avoid problems exactly like this (as well as improve efficiency in large databases, and, most importantly, solve headaches when for example an employee's name changes after a major life event such as marriage or divorce).

Speaking of this, I recently read that Wozniak was employee number 1 at Apple and Job was employee number 2, which made Jobs upset since he wanted to be number one. So he took employee number 0 instead! But the payroll system required a positive integer for employee number, so it didn't really work after all.

Works like a charm! Thank you!

I imported data from a spreadsheet that someone else had made, but didn't have their personnel ID numbers on it. I might have to bite the bullet and look them all up.

That's a neat story about Jobs. Wozniak did all the leg work; he deserved no. 1.
 
Upvote 0

Forum statistics

Threads
1,223,570
Messages
6,173,126
Members
452,502
Latest member
perrygreen98

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top