Jeff and Jon, thanks for your outstanding work, and expect for the two update. 
^^ 



zha...@easemob.com
 
From: Jeff Jirsa
Date: 2016-09-28 13:01
To: user@cassandra.apache.org
Subject: Re: ask for help about exmples of Data Types the document shows
Jon Haddad opened a ticket (presumably based off this email) - 
https://issues.apache.org/jira/browse/CASSANDRA-12718
 
Will get it corrected shortly.
 
 
From: "zha...@easemob.com" <zha...@easemob.com>
Reply-To: "user@cassandra.apache.org" <user@cassandra.apache.org>
Date: Tuesday, September 27, 2016 at 9:57 PM
To: user <user@cassandra.apache.org>
Subject: Re: Re: ask for help about exmples of Data Types the document shows
 
hi, Ben, you are right, I copy the statement from document but not check it 
carefully. It's very helpful and thank a lot !
 
By the way, is there any way to report to the document author and update the 
document? I think it may be confused for a green hand just like me.
 


zha...@easemob.com
 
From: Ben Slater
Date: 2016-09-28 12:50
To: user
Subject: Re: Re: ask for help about exmples of Data Types the document shows
My best guess it that you need to remove the quotes from around the zip values 
(ie change if to  zip: 20500 rather than zip: ‘20500’ ) as zip is defined as an 
int. 
 
Cheers
Ben
 
On Wed, 28 Sep 2016 at 14:38 zha...@easemob.com <zha...@easemob.com> wrote:
Hi, Ben Slater, thank you very much for your replay!
 
my cassandra version is 3.7, so I think there must be some thing  I 
misunderstand  ahout frozen type. I add a comma between } and ‘work’, the 
result is like below. Is there some special form  about " type frozen"?
 
cqlsh:counterks> INSERT INTO user (name, addresses) VALUES ('z3 Pr3z1den7', 
{'home' : {street: '1600 Pennsylvania Ave NW',city: 'Washington',zip: 
'20500',phones: { 'cell' : { country_code: 1, number: '202 456-1111' 
},'landline' : { country_code: 1, number: '...' } }},'work' : {street: '1600 
Pennsylvania Ave NW',city: 'Washington',zip: '20500',phones: { 'fax' : { 
country_code: 1, number: '...' } }}});
InvalidRequest: code=2200 [Invalid query] message="Invalid map literal for 
addresses: value {city: 'Washington', zip: '20500', street: '1600 Pennsylvania 
Ave NW', phones: {'cell': {number: '202 456-1111', country_code: 1}, 
'landline': {number: '...', country_code: 1}}} is not of type frozen<address>" 
 
my create statements about table and type are:
 
cqlsh:counterks> CREATE TYPE phone (     country_code int,     number text, );
cqlsh:counterks> CREATE TYPE address (     street text,     city text,     zip 
int,     phones map<text, frozen<phone>> );
cqlsh:counterks> CREATE TABLE user (
             ...     name text PRIMARY KEY,
             ...     addresses map<text, frozen<address>>
             ... );
 
 
 


zha...@easemob.com
 
From: Ben Slater
Date: 2016-09-28 11:29
To: user
Subject: Re: ask for help about exmples of Data Types the document shows
Hi, 
 
I think you are right about the typo in (1). For (2), I think you’re missing a 
comma between } and ‘work’ so the JSON is invalid.
 
I think reading this JIRA https://issues.apache.org/jira/browse/CASSANDRA-7423 
that the change requiring  a UDT as part of a collection to be explicitly 
marked as frozen is relatively recent (3.6) so the doco may be out date there.
 
Cheers
Ben
 
On Wed, 28 Sep 2016 at 13:12 zha...@easemob.com <zha...@easemob.com> wrote:
hi, everyone, I'm learning Cassandra now , and have some problems about the 
document of "Data Types" .  I don't know where to report or ask for help, so 
I'm very sorry if this mail bother you.
 
In the chapter The Cassandra Query Language (CQL)/Data Types 
(http://cassandra.apache.org/doc/latest/cql/types.html), I'm confused with two 
examples the document showing below. My enviroment is:
 
CentOS release 6.8 (Final)
 
java version "1.8.0_91"
Java(TM) SE Runtime Environment (build 1.8.0_91-b14)
Java HotSpot(TM) 64-Bit Server VM (build 25.91-b14, mixed mode)
 
Python 2.7.11
 
Cassandra version: 3.7
CQL version: [cqlsh 5.0.1 | Cassandra 3.7 | CQL spec 3.4.2 | Native protocol v4]
 
 
1、 in http://cassandra.apache.org/doc/latest/cql/types.html, when describing 
type set, the giving example is:
CREATE TABLE images (    name text PRIMARY KEY,    owner text,    tags 
set<text> // A set of text values);INSERT INTO images (name, owner, tags)       
     VALUES ('cat.jpg', 'jsmith', { 'pet', 'cute' });// Replace the existing 
set entirelyUPDATE images SET tags = { 'kitten', 'cat', 'lol' } WHERE id = 
'jsmith';
the update cql statement uses "WHERE id = 'jsmith'" while the table images did 
not define key "id". I think it's just a slip of the pen.
 
2、 in http://cassandra.apache.org/doc/latest/cql/types.html, when describing 
“User-Defined Types”,  the giving example is:
    CREATE TYPE phone (
    country_code int,    number text,)CREATE TYPE address (    street text,    
city text,    zip int,    phones map<text, phone>)CREATE TABLE user (    name 
text PRIMARY KEY,    addresses map<text, frozen<address>>)
and when I try to create type address, one error occur:
 
cqlsh:counterks> CREATE TYPE address (
             ...     street text,
             ...     city text,
             ...     zip int,
             ...     phones map<text, phone>
             ... );
InvalidRequest: code=2200 [Invalid query] message="Non-frozen UDTs are not 
allowed inside collections: map<text, phone>"
 
I change the create statement, like:
 
CREATE TYPE address (
    street text,
    city text,
    zip int,
    phones map<text, frozen<phone>>
);
 
it works, and the create table user statement works well. Unfortunately, when 
running the insert statement below, error occur:
INSERT INTO user (name, addresses)          VALUES ('z3 Pr3z1den7', {           
   'home' : {                  street: '1600 Pennsylvania Ave NW',              
    city: 'Washington',                  zip: '20500',                  phones: 
{ 'cell' : { country_code: 1, number: '202 456-1111' },                         
   'landline' : { country_code: 1, number: '...' } }              }             
 'work' : {                  street: '1600 Pennsylvania Ave NW',                
  city: 'Washington',                  zip: '20500',                  phones: { 
'fax' : { country_code: 1, number: '...' } }              }          })
error:
SyntaxException: <ErrorMessage code=2000 [Syntax error in CQL query] 
message="line 10:14 mismatched input 'work' expecting '}' (...: '...' } }       
       }              ['wor]k' :...)">
 
 Is the any suggestion about the problem 2?
 
Best wishes for everyone, thank you for your watching !
 


zha...@easemob.com
-- 
———————— 
Ben Slater 
Chief Product Officer
Instaclustr: Cassandra + Spark - Managed | Consulting | Support
+61 437 929 798
-- 
———————— 
Ben Slater 
Chief Product Officer
Instaclustr: Cassandra + Spark - Managed | Consulting | Support
+61 437 929 798
____________________________________________________________________
CONFIDENTIALITY NOTE: This e-mail and any attachments are confidential and may 
be legally privileged. If you are not the intended recipient, do not disclose, 
copy, distribute, or use this email or any attachments. If you have received 
this in error please let the sender know and then delete the email and all 
attachments.

Reply via email to