當前位置: 首頁>>代碼示例>>C#>>正文


C# AbstractConnection類代碼示例

本文整理匯總了C#中AbstractConnection的典型用法代碼示例。如果您正苦於以下問題:C# AbstractConnection類的具體用法?C# AbstractConnection怎麽用?C# AbstractConnection使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


AbstractConnection類屬於命名空間,在下文中一共展示了AbstractConnection類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: SqlEntityDelete

 public SqlEntityDelete(AbstractConnection connection, Entity entity)
     : base(connection) {
     _name = Connection.Enclose(entity.OutputName());
     _isMaster = entity.IsMaster();
     BatchSize = connection.BatchSize;
     UseTransaction = true;
 }
開發者ID:modulexcite,項目名稱:Transformalize,代碼行數:7,代碼來源:SqlEntityDelete.cs

示例2: WriteEndVersion

        public override void WriteEndVersion(Process process, AbstractConnection input, Entity entity, bool force = false) {
            if (entity.Updates + entity.Inserts > 0 || force) {
                var client = new ElasticSearchClientFactory().Create(this, TflBatchEntity(entity.ProcessName));
                var versionType = entity.Version == null ? "string" : entity.Version.SimpleType;

                string end;
                if (versionType.Equals("datetime") && entity.End is DateTime) {
                    end = ((DateTime)entity.End).ToString("yyyy-MM-ddTHH:mm:ss.fff");
                } else if (versionType.Equals("byte[]") || versionType.Equals("rowversion")) {
                    end = Common.BytesToHexString((byte[])entity.End);
                } else {
                    end = new DefaultFactory(Logger).Convert(entity.End, versionType).ToString();
                }

                var body = new {
                    id = entity.TflBatchId,
                    tflbatchid = entity.TflBatchId,
                    process = entity.ProcessName,
                    connection = input.Name,
                    entity = entity.Alias,
                    updates = entity.Updates,
                    inserts = entity.Inserts,
                    deletes = entity.Deletes,
                    version = end,
                    version_type = versionType,
                    tflupdate = DateTime.UtcNow
                };
                client.Client.Index(client.Index, client.Type, body);
            }
        }
開發者ID:modulexcite,項目名稱:Transformalize,代碼行數:30,代碼來源:ElasticSearchConnection.cs

示例3: SqlServerEntityBatchUpdate

 public SqlServerEntityBatchUpdate(AbstractConnection connection, Entity entity)
     : base(connection) {
     _connection = connection;
     _entity = entity;
     BatchSize = connection.BatchSize;
     UseTransaction = true;
 }
開發者ID:modulexcite,項目名稱:Transformalize,代碼行數:7,代碼來源:SqlServerEntityBatchUpdate.cs

示例4: Read

        public Fields Read(AbstractConnection connection, string process, string prefix, string name, string schema, bool isMaster = false) {
            var fields = new Fields();

            using (var cn = connection.GetConnection()) {
                cn.Open();
                var sql = PrepareSql();
                connection.Logger.EntityDebug(name, sql);

                var results = cn.Query(sql, new { name, schema });

                foreach (var result in results) {
                    var columnName = result.COLUMN_NAME;
                    var type = GetSystemType(result.DATA_TYPE);
                    var length = result.CHARACTER_MAXIMUM_LENGTH == "0" || result.CHARACTER_MAXIMUM_LENGTH == "-1" ? "64" : result.CHARACTER_MAXIMUM_LENGTH;
                    var fieldType = (bool)result.IS_PRIMARY_KEY ? (isMaster ? FieldType.MasterKey : FieldType.PrimaryKey) : FieldType.NonKey;
                    var field = new Field(type, length, fieldType, true, string.Empty) {
                        Name = columnName,
                        Entity = name,
                        Process = process,
                        Index = Convert.ToInt16(result.ORDINAL_POSITION - 1),
                        Schema = schema,
                        Input = true,
                        Precision = result.NUMERIC_PRECISION,
                        Scale = result.NUMERIC_SCALE,
                        Alias = prefix + columnName
                    };
                    fields.Add(field);
                }
            }

            return fields;
        }
開發者ID:modulexcite,項目名稱:Transformalize,代碼行數:32,代碼來源:SqlServerEntityAutoFieldReader.cs

示例5: Create

 public static FSDirectory Create(AbstractConnection connection) {
     var directoryInfo = new DirectoryInfo(connection.Folder);
     if (!directoryInfo.Exists) {
         directoryInfo.Create();
     }
     return FSDirectory.Open(directoryInfo);
 }
開發者ID:mindis,項目名稱:Transformalize,代碼行數:7,代碼來源:LuceneDirectoryFactory.cs

示例6: Exists

 public bool Exists(AbstractConnection connection, Entity entity) {
     if (!new DirectoryInfo(LuceneDirectoryFactory.Path(connection, entity)).Exists)
         return false;
     using (var dir = LuceneDirectoryFactory.Create(connection, entity)) {
         return dir.ListAll().Length > 0;
     }
 }
開發者ID:modulexcite,項目名稱:Transformalize,代碼行數:7,代碼來源:LuceneEntityExists.cs

示例7: VistaSystemFileHandler

 public VistaSystemFileHandler(AbstractConnection cxn)
 {
     myCxn = cxn;
     getFileDefs();
     files = new Hashtable();
     lookupTables = new Hashtable();
 }
開發者ID:OSEHRA,項目名稱:mdo,代碼行數:7,代碼來源:VistaSystemFileHandler.cs

示例8: SqlOverrideOperation

 public SqlOverrideOperation(Entity entity, AbstractConnection connection)
     : base(connection) {
     CommandBehavior = CommandBehavior.Default;
     EntityName = entity.Name;
     _entity = entity;
     _fields = entity.Fields.WithInput().NameAliases().ToArray();
 }
開發者ID:modulexcite,項目名稱:Transformalize,代碼行數:7,代碼來源:SqlOverrideOperation.cs

示例9: Exists

 public bool Exists(AbstractConnection connection, Entity entity) {
     using (var cn = connection.GetConnection()) {
         cn.Open();
         var table = cn.Query<string>(SQL, new { name = entity.OutputName() }).DefaultIfEmpty(string.Empty).FirstOrDefault();
         return !string.IsNullOrEmpty(table);
     }
 }
開發者ID:modulexcite,項目名稱:Transformalize,代碼行數:7,代碼來源:MySqlEntityExists.cs

示例10: Execute

        public IScriptReponse Execute(AbstractConnection connection, string script, int timeOut = 0) {
            var response = new ScriptResponse();
            var server = new Server();
            var logger = connection.Logger;

            try {
                logger.Debug("Connecting to {0} on {1}.", connection.Database, connection.Server);
                server.Connect(connection.GetConnectionString());

                var results = server.Execute(script);

                foreach (XmlaResult result in results) {
                    foreach (XmlaMessage message in result.Messages) {
                        response.Messages.Add(message.Description);
                    }
                }
                response.Success = response.Messages.Count == 0;
            } catch (Exception e) {
                logger.Debug(e.Message + (e.InnerException != null ? " " + e.InnerException.Message : string.Empty));
                response.Messages.Add(e.Message);
            } finally {
                if (server.Connected) {
                    logger.Debug("Disconnecting from {0} on {1}.", connection.Database, connection.Server);
                    server.Disconnect();
                }
            }
            return response;
        }
開發者ID:modulexcite,項目名稱:Transformalize,代碼行數:28,代碼來源:AnalysisServicesScriptRunner.cs

示例11: WriteEndVersion

        public override void WriteEndVersion(Process process, AbstractConnection input, Entity entity, bool force = false) {

            if (entity.Updates + entity.Inserts > 0 || force) {

                var solr = GetOperations(process, entity.OutputName());
                var versionType = entity.Version == null ? "string" : entity.Version.SimpleType;

                string end;
                if (versionType.Equals("datetime") && entity.End is DateTime) {
                    end = ((DateTime)entity.End).ToString("yyyy-MM-ddTHH:mm:ss.fff");
                } else if (versionType.Equals("byte[]") || versionType.Equals("rowversion")) {
                    end = Common.BytesToHexString((byte[])entity.End);
                } else {
                    end = new DefaultFactory(Logger).Convert(entity.End, versionType).ToString();
                }

                var doc = new Dictionary<string, object> {
                    { "id", entity.TflBatchId},
                    { "tflbatchid", entity.TflBatchId},
                    { "process", entity.ProcessName},
                    { "connection", input.Name},
                    { "entity", entity.Alias},
                    { "updates", entity.Updates},
                    { "inserts", entity.Inserts},
                    { "deletes", entity.Deletes},
                    { "version", end},
                    { "version_type", versionType},
                    { "tflupdate", DateTime.UtcNow}
                };
                solr.Add(doc);
                solr.Commit();
            }
        }
開發者ID:modulexcite,項目名稱:Transformalize,代碼行數:33,代碼來源:SolrConnection.cs

示例12: Check

 public bool Check(AbstractConnection connection) {
     var result = connection.Name.Equals("output", IC) || new DirectoryInfo(connection.Folder).Exists;
     if (!result) {
         _logger.Warn("Could not verify that '{0}' exists.", connection.Folder);
     }
     return result;
 }
開發者ID:modulexcite,項目名稱:Transformalize,代碼行數:7,代碼來源:FolderConnectionChecker.cs

示例13: WriteEndVersion

        public override void WriteEndVersion(Process process, AbstractConnection input, Entity entity, bool force = false) {
            if (entity.Updates + entity.Inserts <= 0 && !force)
                return;

            var versionType = entity.Version == null ? "string" : entity.Version.SimpleType;
            var end = entity.End ?? new DefaultFactory(Logger).Convert(entity.End, versionType);

            using (var dir = LuceneDirectoryFactory.Create(this, TflBatchEntity(entity.ProcessName))) {
                using (var writer = new IndexWriter(dir, new KeywordAnalyzer(), IndexWriter.MaxFieldLength.UNLIMITED)) {
                    var doc = new Document();
                    doc.fields.Add(new NumericField("id", Libs.Lucene.Net.Document.Field.Store.YES, true).SetIntValue(entity.TflBatchId));
                    doc.fields.Add(new Libs.Lucene.Net.Document.Field("process", entity.ProcessName, Libs.Lucene.Net.Document.Field.Store.YES, Libs.Lucene.Net.Document.Field.Index.NOT_ANALYZED_NO_NORMS));
                    doc.fields.Add(new Libs.Lucene.Net.Document.Field("connection", input.Name, Libs.Lucene.Net.Document.Field.Store.YES, Libs.Lucene.Net.Document.Field.Index.NOT_ANALYZED_NO_NORMS));
                    doc.fields.Add(new Libs.Lucene.Net.Document.Field("entity", entity.Alias, Libs.Lucene.Net.Document.Field.Store.YES, Libs.Lucene.Net.Document.Field.Index.NOT_ANALYZED_NO_NORMS));
                    doc.fields.Add(new NumericField("updates", Libs.Lucene.Net.Document.Field.Store.YES, true).SetLongValue(entity.Updates));
                    doc.fields.Add(new NumericField("inserts", Libs.Lucene.Net.Document.Field.Store.YES, true).SetLongValue(entity.Inserts));
                    doc.fields.Add(new NumericField("deletes", Libs.Lucene.Net.Document.Field.Store.YES, true).SetLongValue(entity.Deletes));
                    doc.fields.Add(LuceneWriter.CreateField("version", versionType, new SearchType { Analyzer = "keyword" }, end));
                    doc.fields.Add(new Libs.Lucene.Net.Document.Field("version_type", versionType, Libs.Lucene.Net.Document.Field.Store.YES, Libs.Lucene.Net.Document.Field.Index.NOT_ANALYZED_NO_NORMS));
                    doc.fields.Add(new NumericField("tflupdate", Libs.Lucene.Net.Document.Field.Store.YES, true).SetLongValue(DateTime.UtcNow.Ticks));
                    writer.AddDocument(doc);
                    writer.Commit();
                    writer.Optimize();
                }
            }
        }
開發者ID:mindis,項目名稱:Transformalize,代碼行數:26,代碼來源:LuceneConnection.cs

示例14: SqlServerEntityKeysExtractFromOutput

 public SqlServerEntityKeysExtractFromOutput(AbstractConnection connection, Entity entity)
     : base(connection) {
     _connection = connection;
     EntityName = entity.Name;
     _entity = entity;
     _fields = new List<string>(new FieldSqlWriter(entity.PrimaryKey).AddDeleted(entity).Alias(connection.L, connection.R).Keys()) { "TflKey" };
     _key = _entity.PrimaryKey;
 }
開發者ID:modulexcite,項目名稱:Transformalize,代碼行數:8,代碼來源:SqlServerEntityKeysExtractFromOutput.cs

示例15: SqlKeysOverrideOperation

        public SqlKeysOverrideOperation(Entity entity, AbstractConnection connection)
            : base(connection) {
            _entity = entity;
            EntityName = entity.Name;
            _fields = entity.PrimaryKey.Aliases().ToArray();
            _length = _fields.Length;

            }
開發者ID:modulexcite,項目名稱:Transformalize,代碼行數:8,代碼來源:SqlKeysOverrideOperation.cs


注:本文中的AbstractConnection類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。