Change Data Capture: Unsubscribed column results in new change set record

I have an installation using Oracle 11g Change Data Capture in synchronous mode. As of writing, I have a single publication and a single subscription. The setup is pretty basic:
PUB_TABLE
PUB_ID*
PUB_NAME*
PUB_USELESS_FLAG
* columns are included in both the PUBLICATION and the SUBSCRIPTION. The final column is of no consequence and is excluded from both the PUBLICATION and SUBSCRIPTION.
My problem is that any time PUB_USELESS_FLAG gets updated (even if no other columns are changed), a record is written to not only the change table but the change table view. The table in question has a significant number of transactions logged against it, but only a subset of those changes are of note to the subscriber (which is why the subscriber does not listen to every column). However, since the subscription is receiving records for every change to the source table, the result is an enormous amount of overhead as the subscriber is forced to sift through numerous records that are of no consequence.
I read the Change Data Capture manual for Oracle 11g; I could not find any reference to the observed functionality. Is this a consequence of using synchronous vs. asynchronous modes of capture? Is there an option to only receive changes on subscribed columns?
Thanks in advance

Bring this to the top because I have the same question. This website (http://www.bikinfo.com/HTML/CDC/CDC_Article.html) makes it sound like this problem is unavoidable.
Edited by: nik_m on Nov 10, 2011 8:04 AM
Edited by: nik_m on Nov 10, 2011 8:05 AM

Similar Messages

  • Change Data Capture in SQL Server

    Post Author: rtamanji
    CA Forum: Data Integration
    I am having primary key constraint problems whenever there is a failure during the data flow from the source to the target, and I have to restart the process. It looks like check points only occurs if the data flows completely ends. How often are these check points initiated ? The AL table keeps track of this value, is there a similarly table to determine the last record read ? Or does DI reads the entire Repcmd table using the last xact_seqno stored ? Thanks for any information.

    It is not using triggers. The source is the transaction log.
    Related link:
    Basics of Change Data Capture
    ...The source of change data for change data capture is the SQL Server transaction log. As inserts, updates, and deletes are applied to tracked source tables, entries that describe those
    changes are added to the log. The log serves as input to the change data capture capture process. This reads the log and adds information about changes to the tracked table’s associated change table. Functions are provided to enumerate
    the changes that appear in the change tables over a specified range, returning the information in the form of a filtered result set. The filtered result set is typically used by an application process to update a representation of the source in some external
    environment. ...
    Kalman Toth, SQL Server & Business Intelligence Training; SQL Server 2008 Training

  • CDC (Change Data Capture) with 2 Tables

    Hello,
    i want to use the change data capture for the typical Data Warehousing progress (bring the new or updatet table from source to the staging area)
    So i have implemented a mapping with to tables. The source table is S_Account, the target or staging table is W_Account_DS.
    I have connected/mapped the tables and in the next step i goes into property inspector of W_ACCOUNT_DS into the Area Change Data Capture --> Change Data Capture Filter and put into the follow expression Builder
    Select *
    from S_Acccount
    where INOUTGRP1.LAST_UPD_DT = CURRENT_DATE (<-- Validation Succesful)
    and the next Step i make Enabeled is true in the Change Data Capture Area. So i think it should ready for one test case.
    I set in SQL Developer with an update statement the LAST_UPD_DT at 28.03.2012 in this case he should not update/insert anything, right? But he insert the full table.
    I set in SQL Developer with an update statement the LAST_UPD_DT by 2 Columms to 28.03.2012 in this case he should update he should update the full table - 2 columns with the date 28.03.2012, right?
    So what make i wrong or have i forgotten anything? (must set keys by the tables? I think not! If yes why?)
    Must i set anything properties else? Why doesnt´work it?
    I look forward for your replies :)

    Setting up CDC is a fairly complex process with different options. Setting just the filter in OWB is only a very small part.
    There is a blog post below on how to use code templates to do CDC which gives some insight;
    http://www.rittmanmead.com/2009/10/changed-data-capture-and-owb11gr2/
    Plus and older one illustrating how to use Oracle logs;
    http://www.rittmanmead.com/2006/04/asynchronous-hotlog-distributed-change-data-capture-and-owb-paris/
    Cheers
    David

  • Change data capture from DRM to Target system

    Hi All,
    I have a situation where client wants Hyperion DRM to be single source of truth and pass Hierarchy information from DRM to subscribing target systems. There are 3 target systems and the database is MS SQL server.
    Now in the export profile ,I am using database export where I have mapped the DRM node/properties to target table's columns. For the initial load it is a new record in the database and the data flows as it is a 1:1 mapping, however if few of the property value changes and I wan to update only the corresponding columns what will the architecture for push the change data in to target.
    Can we achieve this without have any staging tables and capture the change data ?
    Do need to use ODI ?
    Does DRM has any work around without putting extra effort hrs by building CDC tables ?
    I will really appreciate your suggestions and comments on this......

    Thanks for the quick reply. However I was trying to resolve the Change data capture in Hierarcy through as" Database Table" but it seems when we choose the DEVICE option as database in the target tab of export it can only export or insert new records into the tables but cannot update and existing record.
    PLease correct me if my understnding is wrong ?????

  • Change Data Capture, insert+delete instead of update

    Hello everyone,
    I'm having an odd issue, that I need some help understanding.  I've got a number of tables enabled for Change Data Capture, but I've noticed some behavior that doesn't make sense.
    I am utilizing CDC to populate an ODS via SSIS packages, and have noticed a few instances where I'm getting a delete operation come through, but the source record still exists.  In the source system, I can query 'cdc.fn_cdc_get_net_changes_...'
    and see combinations of 1 (delete) and 4 (update new) for the __$operation.
    __$start_lsn, __$operation, TableId, ...
    0x000BB75700002F250005, 1, 1938241
    0x000BB75700002F250005, 4, 1938241
    Also, if I query the cdc.<Table>_CT table directly, I see pairs of 1 and 2 (insert) for the same __$start_lsn and __$seqval.  How can this happen?  If I get *net* changes, shouldn't I only get one record back per the primary
    key of the source table?
    __$start_lsn, __$seqval, __$operation, __$update_mask, TableId, ...
    0x000BB75700002E7C0005, 0x000BB75700002E7C0003, 1, 0x0FFF, 1938241
    0x000BB75700002E7C0005, 0x000BB75700002E7C0003, 2, 0x0FFF, 1938241
    0x000BB75700002F250005, 0x000BB75700002F250003, 1, 0x0FFF, 1938241
    0x000BB75700002F250005, 0x000BB75700002F250003, 2, 0x0FFF, 1938241
    Let me say, I've got a trace going to see if I can find the command(s) that is causing the duplicate results, but has anyone ever seen this before? 
    Thanks in advance for your time and help!
    Jarret

    This is called a deffered update. It is the way that some tables are updated - ie a delete followed by an insert.
    See if the behavior still occurs when using trace flag 8201, ie
    DBCC TRACEON (8207, -1)
    looking for a book on SQL Server 2008 Administration?
    http://www.amazon.com/Microsoft-Server-2008-Management-Administration/dp/067233044X looking for a book on SQL Server 2008 Full-Text Search?
    http://www.amazon.com/Pro-Full-Text-Search-Server-2008/dp/1430215941

  • Change Data Capture How to Tell which you are running Sync or Asyn

    Hi ,
    I am taking over a new system that has change data capture running, but Im really confused how this is running. Most of the CDC is set up using Sync(triggers), but I have about 5 tables that DO NOT have system generated triggers on them. I know Streams is NOT running/configured. I know Capture is not running/configured (because nothing in DBA_CAPTURE table). I can tell that these 5 tables are still getting updated in the change table schema. I can not figure out how the 5 tables that DO NOT have triggers on them are updating the change data set tables.
    I had thought the the 5 tables, must be configured with HOTLOG, but when I look at the CHANGE_SETS table they all (including these 5 tables) are set to CHANGE SOURCE NAME = SYNC SOUCE. I would expected that to be HOTLOG_SOURCE. So I "assume" they aren't set up using Asnc. hot log mode. So maybe the other Async modes are used, but not pushed to another database? Is that possible?
    Any other ideas on how to figure out how the CDC is set up for these 5 tables?
    thanks for your help.

    Thanks for the reply, but I think I must have not stated the problem clearly. I dont WANT to set the source I want to figure out how this CDC is working. I see ALL the sources are currently set to SYNC_SOURCE. Almost all of the tables are set up with system triggers on them, but 5 dont have system triggers, yet the source says SYNC_SOURCE. I did validate that the change tables are getting updated for these tables. my question is how are they getting updated? I "assume" since they dont have system triggers ont eh table they aren't synchoronus cdc (like the other tables are). yet the source says SYNC_SOURCE. What am I missing? How can I tell if the redo log is populating those changes tables? Im pretty sure it is (Becuase there aren't triggers or jobs running), but Im curious if there is a way to tell for sure.
    Thanks,

  • Error While enahling CDC(Change data capture) on Table.

    I am enabling Change data capture (CDC) on SQL server 2012 Enterprise edition(11.0.2100.60)
    . I am able to enable it on Database level with below SQL, but failed to enable on Table level.
    Use DatabaseName
    GO
    Exec sys.sp_cdc_enable_db 
    GO
    EXEC sys.sp_cdc_enable_table @source_schema = N'dbo',
                @source_name = N'TableName', @role_name = NULL
    GO
    Got Error like,
    'msg 22832, Level 16, State 1, Procedure sp_cdc_enable_table_internal, Line 623
    Could not update the metadata that indicates table [dbo].[TableName] is enabled for Change Data Capture. 
    The failure occurred when executing the command '[sys].[sp_cdc_add_job] @job_type = N'capture''. 
    The error returned was 22836: 'Could not update the metadata for database DatabaseName to indicate that a Change Data Capture job has been added. 
    The failure occurred when executing the command 'sp_add_jobstep_internal'. 
    The error returned was 14234: 'The specified '@server' is invalid (valid values are returned by sp_helpserver).'. 
    Use the action and error to determine the cause of the failure and resubmit the request.'. 
    Use the action and error to determine the cause of the failure and resubmit the request.'
    Would anyone help me to out of this?
    Thanks in advance..!!

    Related thread:
    http://social.technet.microsoft.com/Forums/sqlserver/en-US/fa0c2a52-63b5-4a39-9f35-fe6f0eb21d1d/change-data-capture-on-table?forum=sqldatawarehousing
    Make sure SQL Server Agent is running.
    Kalman Toth Database & OLAP Architect
    SQL Server 2014 Design & Programming
    New Book / Kindle: Exam 70-461 Bootcamp: Querying Microsoft SQL Server 2012

  • Change data capture problem?

    Hii,
    i am getting the following error when trying to execute the following procedure.
    SQL>execute dbms_cdc_subscribe.create_subscription(-
    change_set_name => 'SYNC_SET',-
    description => 'This subscription is used for testing',-
    subscription_name => 'TEST_SUBSCRIPTION');
    ERROR at line 1:
    ORA-06550: line 1, column 26:
    PLS-00302: component 'CREATE_SUBSCRIPTION' must be declared
    ORA-06550: line 1, column 7:
    PL/SQL: Statement ignored
    I am trying to implement oracle change data capture in my DB.
    DB version:9.2.0.6
    Can any one help me to sort out this issue please.

    If this package is exists DBMS_CDC_SUBSCRIBE then that Version will support this feature thats my understand.
    This is successfully worked on our DB. Please check syntax like which may have space or anything...
    Replace with your parameters and run, use notepad.
    BEGIN
    DBMS_CDC_SUBSCRIBE.CREATE_SUBSCRIPTION(
    change_set_name => 'PROD1DB_CHANGES',
    description => 'CDC for Cust',
    subscription_name => 'PROD1DB_SUB');
    END;
    /

  • Change Data Capture (CDC) - Best Approach

    Hi,
    I am new to BODI and currently trying to design a change data capture approach.
    In other ETL tools i have used, the last session run timestamp is stored as a parameter and can be called within a mapping. So the mapping updates this parameter everytime it runs. Therefore when implementing CDC the load_date on the table has to be compared to this parameter.
    Is there a similar concept in BODI?
    I appreciate your help.
    Thanks
    Azeem

    Yes, there is such a concept, you have to build it yourself. e.g. https://wiki.sdn.sap.com:443/wiki/display/BOBJ/Inititialize-End+Script
    When you use a CDC enabled datastore however, the database wants to keep track of the data read, that's part of their CDC API. So it is not DI is querying all changes since yesterday, it is a "select * from CDC table" and the database returns just the rows since the last read. Push vs. Pull.

  • Change Data Capture,Change Tables

    Hi,
    We installed Change Data Capture in our DB (10gR2),however there is a problem with change tables.Change tables are being cleaned somehow.According to text quoted below,the job which is cleaning change tables is cdc$_default_purge_job.However
    select log_date
    +, job_name+
    +, status+
    from dba_scheduler_job_log
    where job_name='CDC$_DEFAULT_PURGE_JOB';
    results no data. Also this morning i came across that data cleansing again, and run the query below.And again no result.
    select job_name
    +, session_id+
    +, running_instance+
    +, elapsed_time+
    +, cpu_used+
    from dba_scheduler_running_jobs;
    /*We didn't even use DBMS_SCHEDULER.SET_ATTRIBUTE procedure so far*/
    What is cleaning change tables and how can i control it?
    Tnx in advance
    Quotation:
    Change Data Capture creates a purge job using the
    DBMS_SCHEDULER package (which runs under the account of the publisher who created the first change table). This purge job calls the
    DBMS_CDC_PUBLISH.PURGE procedure to remove data that subscribers are no longer using from the change tables. This job has the name
    cdc$_default_purge_job. By default, this job runs every 24 hours. You can change the schedule of this job using
    DBMS_SCHEDULER.SET_ATTRIBUTE and set the
    repeat_interval attribute. You can verify or modify any other attributes with the
    DBMS_SCHEDULER package.

    Setting up CDC is a fairly complex process with different options. Setting just the filter in OWB is only a very small part.
    There is a blog post below on how to use code templates to do CDC which gives some insight;
    http://www.rittmanmead.com/2009/10/changed-data-capture-and-owb11gr2/
    Plus and older one illustrating how to use Oracle logs;
    http://www.rittmanmead.com/2006/04/asynchronous-hotlog-distributed-change-data-capture-and-owb-paris/
    Cheers
    David

  • Change Data Capture on a view

    I am trying to do change data capture on a view.When i start the journal i am getting error in the "create journal" step.
    BEGIN
    DBMS_CDC_PUBLISH.CREATE_CHANGE_TABLE(
    owner          =&gt; 'DMTRA_TEMPLATE',
    change_table_name     =&gt; 'J$BIEO_HYP_EXP_ORG_WEEK',
    change_set_name     =&gt; 'DEMANTRA_SOURCE',
    source_schema     =&gt; 'DMTRA_TEMPLATE',
    source_table     =&gt; 'BIEO_HYP_EXP_ORG_WEEK',
    column_type_list     =&gt; 'SDATE DATE ,LEVEL1 VARCHAR2(2000) ',
    capture_values     =&gt; 'new',
    rs_id          =&gt; 'n',
    row_id          =&gt; 'n',
    user_id          =&gt; 'n',
    timestamp          =&gt; 'n',
    object_id          =&gt; 'n',
    source_colmap     =&gt; 'n',
    target_colmap     =&gt; 'n',
    options_string     =&gt; ''
    END;
    The error that i am getting is:
    java.sql.BatchUpdateException: ORA-31419: source table does not exist
    ORA-06512: at "SYS.DBMS_CDC_PUBLISH", line 611.
    I want to know is it possible to do CDC on a view.And if yes,then is the procedure to be followed any different than the one used for a table?

    I'm afraid this is not possible!!!!

  • Changed Data Capture (CDC) when view as a Source

    Hello All,
    We implemented Changed Data Capture (CDC) by taking table as a source and we used to JKM Oracle Simple KM and it is working fine. But, we need to implement CDC by taking View as a source. Included Primary key at ODI Level for this view as CDC requires this on the source.
    As we cannot create triggers on views and also while creating journal view prefixed with JV${table_name}, getting the following errror:
    "1446 : 72000 : java.sql.SQLException: ORA-01446: cannot select ROWID from view with DISTINCT, GROUP BY, etc."
    How can we achieve CDC if our source is a view?
    Any suggestions..
    Thanks,
    -Vency

    Hi,
    Its not issue of a "lock" so no luck..
    Its definitely the issue with the view..
    I also got the real error as:
    ORA-012024:Cannot select FOR UPDATE from view with DISTINCT,GROUP by etc..
    Wonder why this is the error, as my view does not have DISTINCT,GROUP By etc..
    Also checked
    select * from USER_UPDATABLE_COLUMNS ;
    and found that none of the columns are updateable..
    So how to make these updateable and get my form work?

  • Distributed Hotlog Change Data Capture (CDC) on 10.2.0.3 - Very Urgent

    Hello all,
    I am trying to set up distributed Hotlog Change Data Capture (CDC) with both source and staging databases on 10.2.0.3. I have managed to set up everything alright until I try to great my first change table on the staging database.
    We tried runnning this:
    begin
         dbms_cdc_publish.create_change_table(
              owner => 'CDC_STG9_PUB',
              change_table_name => 'ed_test_1_CT',
              change_set_name => 'CR_FN9_SET',
              source_schema => 'CIS',
              source_table => 'ed_cdc_test_1',
              column_type_list => 'col1 number, col2 varchar2(20)',
              capture_values => 'both',
              rs_id => 'y',
              row_id => 'n',
              user_id => 'n',
              timestamp => 'n',
              object_id => 'n',
              source_colmap => 'n',
              target_colmap => 'y',
              options_string => null) ;
    end ;
    I sometimes get this:
    begin
    ERROR at line 1:
    ORA-00942: table or view does not exist
    ORA-06512: at "SYS.DBMS_CDC_PUBLISH", line 611
    ORA-06512: at line 2
    Re-running the create change set seems to solve this.
    However, when I try to run enable the change source, I get this:
    begin
    ERROR at line 1:
    ORA-31532: cannot enable change source CR_FN9_SRC
    ORA-06512: at "SYS.DBMS_CDC_IPUBLISH", line 151
    ORA-06512: at "SYS.DBMS_CDC_PUBLISH", line 497
    ORA-06512: at line 2
    Any ideas would be very well appreciated.

    The alert log file reads:
    Errors in file /oracle/DXCE/lvol11/background/dxce_j000_24285.trc:
    ORA-12012: error on auto execute of job 10
    ORA-06550: line 1, column 96:
    PLS-00201: identifier 'SYS.DBMS_CDC_PUBLISH' must be declared
    ORA-06550: line 1, column 96:
    PL/SQL: Statement ignored
    Fri Mar 9 11:50:51 2007
    Streams APPLY A002 started with pid=23, OS id=24304
    Streams Apply Reader started P000 with pid=24 OS id=24306
    Streams Apply Server started P001 with pid=25 OS id=24308
    dxce_j000_24285.trc reads:
    Oracle Database 10g Enterprise Edition Release 10.2.0.3.0 - 64bit Production
    With the Partitioning, OLAP and Data Mining options
    ORACLE_HOME = /oraxcd/10.2.0.3
    System name: SunOS
    Node name: stwu01
    Release: 5.10
    Version: Generic_118833-24
    Machine: sun4v
    Instance name: DXCE
    Redo thread mounted by this instance: 1
    Oracle process number: 29
    Unix process pid: 24285, image: oracle@stwu01 (J000)
    *** ACTION NAME:() 2007-03-08 14:57:15.007
    *** MODULE NAME:() 2007-03-08 14:57:15.007
    *** SERVICE NAME:(SYS$USERS) 2007-03-08 14:57:15.007
    *** CLIENT ID:() 2007-03-08 14:57:15.007
    *** SESSION ID:(541.1371) 2007-03-08 14:57:15.007
    *** 2007-03-08 14:57:15.007
    ORA-12012: error on auto execute of job 10
    ORA-06550: line 1, column 96:
    PLS-00201: identifier 'SYS.DBMS_CDC_PUBLISH' must be declared
    ORA-06550: line 1, column 96:
    PL/SQL: Statement ignored
    Regards,
    Edosa

  • Can you help me about change data captures in 10.2.0.3

    Hi,
    I made research about Change Data Capture and I try to implement it between two databases for two small tables in 10g release 2.MY CDC implementation uses archive logs to replicate data.
    Change Data Capture Mode Asynchronous autolog archive mode..It works correctly( except for ddl).Now I have some questions about CDC implementation for large tables.
    I have one senario to implement but I do not find exactly how can I do it correctly.
    I have one table (name test) that consists of 100 000 000 rows , everyday 1 000 000 transections occurs on this table and I archive the old
    data more than one year manually.This table is in the source db.I want to replicate this table by using Change Data Capture to other stage database.
    There are some questions about my senario in the following.
    1.How can I make the first load operations? (test table has 100 000 000 rows in the source db)
    2.In CDC, it uses change table (name test_ch) it consists of extra rows related to opearations for stage table.But, I need the orjinal table (name test) for applicaton works in stage database.How can I move the data from change table (test_ch) to orjinal table (name test) in stage database? (I don't prefer to use view for test table)
    3.How can I remove some data from change table(name test_ch) in stage db?It cause problem or not?
    4.There is a way to replicate ddl operations between two database?
    5. How can I find the last applied log on stage db in CDC?How can I find archive gap between source db and stage db?
    6.How can I make the maintanence of change tables in stage db?

    Asynchronous CDC uses Streams to generate the change records. Basically, it is a pre-packaged DML Handler that converts the changes into inserts into the change table. You indicated that you want the changes to be written to the original table, which is the default behavior of Streams replication. That is why I recommended that you use Streams directly.
    <p>
    Yes, it is possible to capture changes from a production redo/archive log at another database. This capability is called "downstream" capture in the Streams manuals. You can configure this capability using the MAINTAIN_* procedures in DBMS_STREAMS_ADM package (where * is one of TABLES, SCHEMAS, or GLOBAL depending on the granularity of change capture).
    <p>
    A couple of tips for using these procedures for downstream capture:
    <br>1) Don't forget to set up log shipping to the downstream capture database. Log shipping is setup exactly the same way for Streams as for Data Guard. Instructions can be found in the Streams Replication Administrator's Guide. This configuration has probably already been done as part of your initial CDC setup.
    <br>2) Run the command at the database that will perform the downstream capture. This database can also be the destination (or target) database where the changes are to be applied.
    <br>3) Explicitly define the parameters capture_queue_name and apply_queue_name to be the same queue name. Example:
    <br>capture_queue_name=>'STRMADMIN.STREAMS_QUEUE'
    <br>apply_queue_name=>'STRMADMIN.STREAMS_QUEUE'

  • OWB Support for Change Data Capture

    Hi All,
    Has anyone got OWB working with the Change Data Capture feature in the Oracle 9i database? I understand that CDC works by publishing changes through an advanced queue, which in theory OWB 9.0.4 upwards can have as a data source, but there doesn't appear to be any explicit support within the GUI for capturing CDC changes.
    I'm also working on the assumption that we're talking about Synchronous CDC as found in 9i. 10g comes with Asynchronous CDC which I guess presents a different interface to the receiving program.
    So - is there any support for 9i Change Data Capture in OWB, and has anyone got this to work in practice?
    thanks
    Mark

    Mark,
    There is currently no explicit support for the 9i CDC. You can use Advanced Queues to propagate the changes, but you will have to custom-build the capture infrastructure on the source side (set up the CDC, enqueue the changes in the appropriate form into the AQ etc.)
    OWB will explicitly support CDC (10g async, which is the least invasinve method) in our next major release currently scheduled to be release in November of this year.
    Regards:
    Igor

Maybe you are looking for

  • ANIMATED GIF IN A LAYERED PHOTOSHOP FILE

    I created a photoshop file with text and background layers.  The client wants me to place an animated GIF in the center of the file. How do I get all but 3 layers which comprise the animated GIF to not go into the animated gif timeline on the bottom

  • Adobe Flash Player 11.4 says it stopped working, but I still works

    Almost every time I open Firefox, I get a message saying that Adobe Flash Player 11.4 has stopped working. However, I don't seem to have any problem playing anything that uses Adobe. Every time I close the message window, it immediately pops back up.

  • Best phone for syncing with Office for Mac 2008?

    I'll be getting a new phone in a few months and I want to get one that syncs perfectly and effortlessly with Office for Mac 2008. I currently use a Motorola Q and a Macbook Pro and have to go through isyncing Office with the Mac versions (iCal and Ad

  • Observable vs Custom Events

    Hi. I'm creating a project that uses the MVC design pattern, and being eager to make sure I follow the best practices I have a couple of questions. When notifying a 'View' of changes to the 'Model' is it preferable to effect this notfication using th

  • ALE methods in SAP General Ledger

    Hi, I am working on SAP General Ledger. I heard that data is transferred to the central general ledger using ALE methods which are part of the General Ledger Accounting (FI-GL) component. I know a about ALE but I am trying to grasp what does it mean