| Author | Topic | 
                            
                                    | michaeldunnjrStarting Member
 
 
                                        3 Posts | 
                                            
                                            |  Posted - 2008-03-14 : 18:16:49 
 |  
                                            | When I am initializing a transactional replication from SQL 2005 to Oracle 10g, SQL tries to drop tables that don't exist.  The properties option for the articles specifically states "if the name is in use:".  The name is not in use, yet SQL still tries to drop non-existent tables, which causes the replication to halt.  Anyone seen this before, or have any ideas what to do about it?Thanks! |  | 
       
                            
                       
                          
                            
                                    | tkizerAlmighty SQL Goddess
 
 
                                    38200 Posts | 
                                        
                                          |  Posted - 2008-03-14 : 18:45:06 
 |  
                                          | Just don't bother with the snapshot.  Manually get the tables in sync, then startup the log reader job.Tara KizerMicrosoft MVP for Windows Server System - SQL Serverhttp://weblogs.sqlteam.com/tarad/ |  
                                          |  |  | 
                            
                       
                          
                            
                                    | sodeepMaster Smack Fu Yak Hacker
 
 
                                    7174 Posts | 
                                        
                                          |  Posted - 2008-03-14 : 18:46:19 
 |  
                                          | This will help :http://www.microsoft.com/technet/prodtechnol/sql/2005/technologies/repl_quickstart_for_oracle.mspx |  
                                          |  |  | 
                            
                       
                          
                            
                                    | michaeldunnjrStarting Member
 
 
                                    3 Posts |  | 
                            
                       
                          
                            
                                    | tkizerAlmighty SQL Goddess
 
 
                                    38200 Posts | 
                                        
                                          |  Posted - 2008-03-15 : 00:44:53 
 |  
                                          | Well you could export your data via bcp, SSIS, or some other method, and then import it into Oracle or you could try adding a linked server on the SQL Server pointing to the Oracle server and then use something like this:insert into linkedservername.databasename.ownername.tablenameselect * from dbo.tablename swhere not exists (select * from linkedservername.databasename.ownername.tablename o where s.pkcolumnname = o.pkcolumnname)Tara KizerMicrosoft MVP for Windows Server System - SQL Serverhttp://weblogs.sqlteam.com/tarad/ |  
                                          |  |  | 
                            
                       
                          
                            
                                    | michaeldunnjrStarting Member
 
 
                                    3 Posts | 
                                        
                                          |  Posted - 2008-03-16 : 19:46:57 
 |  
                                          | quote:Thank linked server option sounds like a promising suggestion.  I just have one other question then, as I'm a bit of a novice to replication.  When I've created transactional publications in the past, it always wants to initialize the subscription with a snapshot.  Do you know of a way around that?Thanks again!Originally posted by tkizer
 Well you could export your data via bcp, SSIS, or some other method, and then import it into Oracle or you could try adding a linked server on the SQL Server pointing to the Oracle server and then use something like this:insert into linkedservername.databasename.ownername.tablenameselect * from dbo.tablename swhere not exists (select * from linkedservername.databasename.ownername.tablename o where s.pkcolumnname = o.pkcolumnname)Tara KizerMicrosoft MVP for Windows Server System - SQL Serverhttp://weblogs.sqlteam.com/tarad/
 
 |  
                                          |  |  | 
                            
                       
                          
                            
                                    | sodeepMaster Smack Fu Yak Hacker
 
 
                                    7174 Posts | 
                                        
                                          |  Posted - 2008-03-16 : 19:55:27 
 |  
                                          | You can  do transactional replication with Backup/restore too which is "initialize with backup" |  
                                          |  |  | 
                            
                       
                          
                            
                                    | rmiaoMaster Smack Fu Yak Hacker
 
 
                                    7266 Posts | 
                                        
                                          |  Posted - 2008-03-16 : 22:53:10 
 |  
                                          | Backup/restore doesn't work if target db has something you need to keep. |  
                                          |  |  | 
                            
                       
                          
                            
                                    | sodeepMaster Smack Fu Yak Hacker
 
 
                                    7174 Posts | 
                                        
                                          |  Posted - 2008-03-16 : 23:15:37 
 |  
                                          | Sorry, didn't get what you meant. |  
                                          |  |  | 
                            
                       
                          
                            
                                    | rmiaoMaster Smack Fu Yak Hacker
 
 
                                    7266 Posts | 
                                        
                                          |  Posted - 2008-03-16 : 23:25:13 
 |  
                                          | When set replication, you can replicate tables to db that has different set of tables you want to keep for other processes. If you do backup/restore, you'll destroy those tables. |  
                                          |  |  | 
                            
                       
                          
                            
                                    | tkizerAlmighty SQL Goddess
 
 
                                    38200 Posts | 
                                        
                                          |  Posted - 2008-03-16 : 23:35:15 
 |  
                                          | quote:In my environment, I can't run a snapshot as we need to keep the layout and existing data in the subscriber database.  So I always unselect the option to perform a snapshot and I also disable the snapshot job (and sometimes delete it).Tara KizerMicrosoft MVP for Windows Server System - SQL Serverhttp://weblogs.sqlteam.com/tarad/Originally posted by michaeldunnjr
 
 quote:Thank linked server option sounds like a promising suggestion.  I just have one other question then, as I'm a bit of a novice to replication.  When I've created transactional publications in the past, it always wants to initialize the subscription with a snapshot.  Do you know of a way around that?Thanks again!Originally posted by tkizer
 Well you could export your data via bcp, SSIS, or some other method, and then import it into Oracle or you could try adding a linked server on the SQL Server pointing to the Oracle server and then use something like this:insert into linkedservername.databasename.ownername.tablenameselect * from dbo.tablename swhere not exists (select * from linkedservername.databasename.ownername.tablename o where s.pkcolumnname = o.pkcolumnname)Tara KizerMicrosoft MVP for Windows Server System - SQL Serverhttp://weblogs.sqlteam.com/tarad/
 
 
 |  
                                          |  |  | 
                            
                            
                                |  |