Right. So in a column defined as integer not null, there must then be a default 
value when you pass empty otherwise there would be an inconsistency. What I do 
( and how I do it is too much to go into on an iPhone) is I preload all the 
values I intend to insert/update with default values, then get input from the 
user. If the user does not alter the defaults, then the SQL table gets the ones 
I defined. The best way however is to define your table columns with some 
default. I have learned to do this at pains to The contrary. 

Bob Sneidar
IT Manager
Calvary Chapel CM
Sent from iPhone

On Feb 21, 2012, at 18:42, Mark Smith <mark_sm...@cpe.umanitoba.ca> wrote:

> 
> slylabs13 wrote
>> 
>> What is the field type? What is the default? If numeric and not null then
>> it may be that the value defaults to 0
>> 
> 
> Thanks Bob, field type is integer, no default is defined. Firefox plugin has
> a zero in the Not Null column,(which means?) and a zero in the Primary Key
> column (which I presume means the field is not a primary key). 
> 
> Just to add to my previous comments, I thought I would check to see if it
> had anything to do with the substitution form of revExecuteSQL. It did not.
> Switching back to
> 
> 
>  put "UPDATE test SET " & \
>         merge("one='[[tOne]]', two='[[tTwo]]', three='[[tThree]]'") & \
>         " WHERE id = " & tID into tCmd  -- old format
> 
> had the same result. One advantage though was that if I put a "Put tCmd" to
> throw the statement to the msg box I could actually see what the values
> were. For the first save of the empty fields (UPDATE statement above) it
> looks like this:
> 
> UPDATE test SET one='', two='', three='' WHERE id = 10
> 
> field types are integer, integer and text respectively
> 
> After reading it back in, it displays 0's in the int fields. If I then try
> saving it again (running the same code as above) I get this:
> 
> UPDATE test SET one='0', two='0', three='' WHERE id = 10
> 
> and as you can see the int fields now contain 0's while the text field does
> not. No data entry has occurred on my part, I am just executing a repeated
> read and write on the same record using the same code. Bob may be on to
> something though.... maybe I have to define a default... but what should
> that be (I want undefined to remain undefined)?
> 
> -- Mark
> 
> 
> --
> View this message in context: 
> http://runtime-revolution.278305.n4.nabble.com/Anomoly-when-storing-empty-values-into-SQLite-integer-fields-tp4408942p4409072.html
> Sent from the Revolution - User mailing list archive at Nabble.com.
> 
> _______________________________________________
> use-livecode mailing list
> use-livecode@lists.runrev.com
> Please visit this url to subscribe, unsubscribe and manage your subscription 
> preferences:
> http://lists.runrev.com/mailman/listinfo/use-livecode

_______________________________________________
use-livecode mailing list
use-livecode@lists.runrev.com
Please visit this url to subscribe, unsubscribe and manage your subscription 
preferences:
http://lists.runrev.com/mailman/listinfo/use-livecode

Reply via email to