|
Posted by Darko on 11/08/07 14:45
On Nov 8, 2:28 pm, Jerry Stuckle <jstuck...@attglobal.net> wrote:
> Steve wrote:
> > "The Natural Philosopher" <a...@b.c> wrote in message
> >news:1194484441.81272.6@demeter.uk.clara.net...
> >> Darko wrote:
> >>> On Nov 7, 10:37 pm, "Steve" <no....@example.com> wrote:
> >>>> "Darko" <darko.maksimo...@gmail.com> wrote in message
>
> >>>>news:1194463439.305946.20240@z9g2000hsf.googlegroups.com...
>
> >>>>> On Nov 7, 6:19 pm, "Steve" <no....@example.com> wrote:
> >>>>>> well !!! lo-and-behold!!! when you get your error message back THIS
> >>>>>> time,
> >>>>>> you actually get a line number OTHER THAN 1 !!! now THAT would be
> >>>>>> helpful!
> >>>>>> imagine too, that you echo this out to the browser, copy it, and paste
> >>>>>> it
> >>>>>> directly into your mysql query browser...then execute it. even before
> >>>>>> then,
> >>>>>> you might have discovered (since you can now READ IT) that there is
> >>>>>> something wrong in the data you're inserting.
> >>>>> Having yelled that out, haven't you ever noticed that mysql (and so do
> >>>>> other
> >>>>> sql servers) specify precisely where the problem is - this time it
> >>>>> said:
> >>>>>> near 'from, size, format, cat, host ...
> >>>> you obviously haven't written very long or complex queries. 'near' and
> >>>> ON
> >>>> LINE x are *worlds* apart, now aren't they.
>
> >>>>> ... so it was quite clear that it had had problem with "from".
> >>>> apparently not quite as clear to the op. :)
>
> >>>>> Considering php and
> >>>>> queries code readability you are, of course, right, since a programmer
> >>>>> will much more
> >>>>> easily read the code formatted in the way you have, but considering
> >>>>> error information,
> >>>> you should ammend that...'considering the error information [IN THIS
> >>>> CASE]'.
>
> >>>> either way, it should be formatted as a rule...unless you're saying you
> >>>> can
> >>>> predict your errors, in which case you wouldn't make mistakes anyway.
>
> >>>>> sql servers are pretty precise about where the problem occurred, code
> >>>>> being indented
> >>>>> or not.
> >>>> really? which ones? what is 'pretty' precise?
>
> >>>> the indenting is multipurpose. it is my experience that the top 4 sql
> >>>> servers (ms sql, oracle, mysql, teradata) are generally *obtuse* in
> >>>> their
> >>>> error messages...but they all give line numbers!
>
> >>>>>> don't let me throw you on that one...bad data is NOT the problem here.
> >>>>>> there
> >>>>>> are things called RESERVED WORDS. one of those would be the word
> >>>>>> 'FROM'...as
> >>>>>> in "select * FROM". if you had correctly formatted your sql statement,
> >>>>>> the
> >>>>>> line number in error would have been line 6...a much better clue.
> >>>>> As for rude yelling about making mistakes with reserved words, that is
> >>>>> something that happens
> >>>>> to many people, even experienced, from time to time, so no need to get
> >>>>> upset about it.
> >>>> rude? lol.
>
> >>>> you even infer rudeness about the mistake itself. no, i capitalized FROM
> >>>> so
> >>>> that it stood out. if that hurt your ears, then you won't hear me
> >>>> laughing
> >>>> right now. my intention throughout the thread here has been to make a
> >>>> point
> >>>> about formatting. did you not notice that even though i told him what
> >>>> the
> >>>> problem was, i did not tell him how to fix it? hmmmm...must not have
> >>>> been
> >>>> the goal of my post. seems you've missed that point.
>
> >>>>> I once
> >>>>> named two variables in C like "od" and "do", and couldn't find out
> >>>>> what was wrong with it until
> >>>>> I realised it was the "do" keyword.
> >>>> christ almighty! i suppose you proliferate the use of variables like
> >>>> $tmp
> >>>> too. what a goof! 'do'? for the love of god, almost *every* language has
> >>>> a
> >>>> *do* loop construct. so, when you said, 'even experienced' above, you
> >>>> were
> >>>> not associating yourself among those. :)
>
> >>>>> Finally, it is not "reserved" word in any sql, as you can indeed name
> >>>>> any field "from", as long
> >>>>> as you make the parser know it. For an example, this is totally legal:
> >>>>> select name, img, descr, "from", size, format from table;
> >>>> why yes. now why would i NOT explain that to the op? must not have been
> >>>> the
> >>>> purpose of my post. what's more, i'd be encouraging BAD behavior. if you
> >>>> think that's just my ho, why don't you prepose that question in a db
> >>>> forum...bring your asbestos umbrella, cuz it'll rain fire from the first
> >>>> response to the last. dba's are kinda picky that way.
>
> >>>>> just as long as you keep the double quotes around key words.
> >>>> ahhhh...you assume too much. oracle will fart on your double quotes. it
> >>>> likes either single tics or single back tics (`). again, you just killed
> >>>> a
> >>>> great chance for scalability. you should be able to take your code base
> >>>> and
> >>>> plop it down in front of any db and nothing breaks. you've forced
> >>>> yourself
> >>>> to reprogram when switching from one db to another...which is the shits
> >>>> when
> >>>> you're prototyping on your local pc using mysql and pushing code to
> >>>> production where teradata is the db being used.
>
> >>>> wanna keep going, darko?
> >>> Yes, please.
>
> >>> It wasn't my intention to encourage Einstein30000 to use such field
> >>> names as "from" or "select",
> >>> the idea was only that such errors happen even to experienced
> >>> programmers, not indicating whether
> >>> I consider myself one or not - it's pretty relative thing, as you
> >>> know.
>
> >>> As for "od" and "do", you should first know that I am a Serb, and that
> >>> in Serbian language "od" means "from",
> >>> and "do" means "to", so "od 1 do 10" means "from 1 to 10". Thus, once
> >>> in a simple C program I needed such "from" and
> >>> "to" helper variables, and I named them "od" and "do". It would have
> >>> been much easier to avoid if I was writing in
> >>> English, which I usually do when making non-test programs, since then
> >>> it would be easier to "hear" it as the English
> >>> do. But, being switched to Serbian in my mind, I didn't see any danger
> >>> coming of it, and the
> >>> compiler was pretty vague about the error, as you know it can be, and
> >>> I hardly recognized it. This is,
> >>> if you'd really like to know.
>
> >>> As for yelling, your uppercasing "FROM" explanation doesn't mention
> >>> the "your sql statement is F.U.C.K.E.D", "well !!! lo-and-behold!!!",
> >>> "a line number OTHER THAN 1 !!! now THAT would be helpful! ", "since
> >>> you can now READ IT", "bad data is NOT the problem here. there are
> >>> things called RESERVED WORDS. " statements, which I normally
> >>> considered yelling. It's just not polite to address people like that,
> >>> especially ones that came for advice and help.
>
> >>> Regards,
> >>> Darko
>
> >> I'm with darko here. It took me about 5 seconds flat to realise what was
> >> wrong.
>
> >> No need to blow it across 15 lines.
>
> >> Unless you are the sort person who can't count beyond ten without taking
> >> their socks off.
>
> >> Mysql barfs where its parser gets confused..that was at the word 'from'
> >> Simple.
>
> > right. and no one is arguing the simple nature of identifying the problem
> > here. however, it becomes very difficult, not only to read, but to maintain
> > and debug sql statements that are not well formatted...which helps more
> > quickly identify the root cause when it is less than obvious.
>
> > i'm not for or against anyone. i'm for a systemic approach that covers all
> > the bases and is a best practice. that's all. it has little to do with the
> > actual problem faced here with reserved words.
>
> Sorry, Steve - I don't agree with your method of "properly formatting"
> the SQL. It takes way too much space on the page. It is not "correct"
> by virtually any programmer I know.
>
> --
> ==================
> Remove the "x" from my email address
> Jerry Stuckle
> JDS Computer Training Corp.
> jstuck...@attglobal.net
> ==================
I must agree with you on this one. I do format my queries in code, but
it looks something like this:
$query = sprintf(
"INSERT INTO " .
"main " .
"(name, img, descr, from, size, format, cat, host, link, date)
" .
"VALUES " .
"('%s', '%s', '%s', '%s', %f, '%s', '%s', '%s', '%s', '%s')",
mysql_real_escape_string( $name ),
...
);
$queryResult = @mysql_query( $query );
if ( $queryResult === FALSE ) {
throw new Exception( "..." );
....
....with exception, of course, that I would try to avoid the "from"
sort of variable
names. This is pretty shorter, and still good enough to understand (at
least for me)
Darko
Navigation:
[Reply to this message]
|