Solved

SQL Query - Update Syntax issue with Apostrophe

Posted on 2009-04-09
7
492 Views
Last Modified: 2012-05-06
I am creating a small application for taking notes etc.  However, in my textbox when I use any Apostrophe, the program is giving me error.  

Incorrect syntax near 's'.  Unclosed quotation mark after the character string ')'.  

So any way to get around this?
0
Comment
Question by:holemania
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
7 Comments
 
LVL 12

Expert Comment

by:Nathan Riley
ID: 24111135
us 2 '.  Like if it is

'This is Bob's House'

should be

'This is Bob''s House'
0
 
LVL 65

Expert Comment

by:rockiroads
ID: 24111203
how are you creating this sql?
if manually i.e. in code (not bounded forms) then wrap that field with double quotes

eg

dim sSql as string

sSql = "update mytable set myfield = " & chr$(34) & myvalue & chr$(34)

chr$(34) is basically double quotes that u wrap your variable in
0
 
LVL 9

Accepted Solution

by:
Sreedhar Vengala earned 250 total points
ID: 24111295
OK, so you're wanting your values to include the surrounding apostrophes in
the values stored on the database.  IN that case, you need to use *three*
apostrophes.  This is because you want to leave a single apostrophe to tell
the parser that the enclosed value is a string, but also include double
apostrophes to tell the parser to generate a single apostrophe after parsing
the SQL.  I.e.

Insert into table values('''fields''', '''morefields''');

Now this may cause problems, depending on how good the SQL parser you are
using is.  For instance, if it always generates a single apostrophe from the
first double apostrophe it finds, you may end up back where you were with
the two apostrophe example you gave.

There is another, simpler alternative of course.  Use double quotes instead
of apostrophes in your strings.  I.e.

Insert into table values('"fields"', '"morefields"');

It all depends on why you want the apostrophes to be stored in the fields
with the values.  If you're going to use them in processing later when the
data is read, then you can easily do a replace of the double quotes with
apostrophes after the values are read from the database.  Off my head, I
can't think why you would want to enclose values in apostrophes like this,
as the data type of the field should already know they are strings, so
storing them with the data seems a bit redundant.
0
Learn by Doing. Anytime. Anywhere.

Do you like to learn by doing?
Our labs and exercises give you the chance to do just that: Learn by performing actions on real environments.

Hands-on, scenario-based labs give you experience on real environments provided by us so you don't have to worry about breaking anything.

 
LVL 65

Assisted Solution

by:rockiroads
rockiroads earned 250 total points
ID: 24111632
Sorry, I thought I was in the msaccess zone, lol

but with sql, to wrap a string with single quotes, wrap it in double quotes. It sill applies except you would use   "  (shift 2)
0
 

Author Comment

by:holemania
ID: 24111707
Below is how my query looks like.  My richtextbox, I want the user to type in notes and sometimes when they using apostrophe in the note, it throw the error.

My snytax:
Dim strInsert As String = "INSERT INTO NOTE VALUES(" & strNoteID & ", " & txtID.TEXT & ", '" & rtbNote.TEXT & "')"


This part of the syntax '" & rtbNote.TEXT & "' is what is giving me the error.
0
 

Author Comment

by:holemania
ID: 24111853
Okay this seems fix the issue.

Dim strNote as String = Replace(rtbNote.Text, "'", "''")

Dim strInsert As String = "INSERT INTO NOTE VALUES(" & strNoteID & ", " & txtID.TEXT & ", '" & strNote & "')"
0
 

Author Closing Comment

by:holemania
ID: 31568720
Thanks for the help.  Not quite what I was looking for me steer me in the right direction.

Basically replacing ' with double '' seems to fix the issue.
0

Featured Post

How to Create Failover DNS Record Sets in Route 53

Route 53 has the ability to easily configure DNS record sets specifically for failover scenarios. These failover record sets can be configured to failover to full-blown deployments in other regions or to a static HTML page that informs your customers of the issue.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

If you have heard of RFC822 date formats, they can be quite a challenge in SQL Server. RFC822 is an Internet standard format for email message headers, including all dates within those headers. The RFC822 protocols are available in detail at:   ht…
It is possible to export the data of a SQL Table in SSMS and generate INSERT statements. It's neatly tucked away in the generate scripts option of a database.
In this video, viewers are given an introduction to using the Windows 10 Snipping Tool, how to quickly locate it when it's needed and also how make it always available with a single click of a mouse button, by pinning it to the Desktop Task Bar. Int…
Visualize your data even better in Access queries. Given a date and a value, this lesson shows how to compare that value with the previous value, calculate the difference, and display a circle if the value is the same, an up triangle if it increased…
Suggested Courses

630 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question