Nano Hash - криптовалюты, майнинг, программирование

ошибка открытия соединения с оракулом

Я использую QTP/UFT для тестирования приложений. Мне пришлось получить доступ к моей базе данных оракула (11g), чтобы выполнить некоторую настройку базы данных (для обновления записей).

Я использую oracle.manageddataaccess.dll (ссылка на проект библиотеки классов myDBWrapper).

у меня ниже dll

(myDBWrapper - это тот, который я создал, где присутствует проблема)

введите здесь описание изображения

Моя строка подключения:

Data Source=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=<HOST>)(PORT=<PORT>>)))(CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=<SERVICENAME>)));User Id=<USERNAME>;Password=<PASSWORD>;

Проблема:

Приведенный ниже код во время conn.open() выдает ошибку. Иногда это работает, а иногда выдает ошибку, что «Ссылка на объект не устанавливает экземпляр объекта» на том же компьютере.

conn = New OracleConnection()
conn.ConnectionString = ConnectionString
MsgBox("isnothing? : " & (conn Is Nothing).ToString)   'it is always False. So , not null

conn.Open()  ' It throws an error that "Object reference not to set an instance of an object"

Dim cmd As OracleCommand = New OracleCommand(strQuery)
cmd.BindByName = True
cmd.Connection = conn
RowsAffected = cmd.ExecuteNonQuery()
cmd.Dispose()
conn.Dispose()

Примечание:

Это не утечка ресурсов. Я просто делаю 1 соединение и избавляюсь. Никто больше не подключается к БД.

Возникает проблема - когда QTP имеет COM-библиотеку. Когда я использую это, чтобы автоматизировать и сделать его невидимым (QTP.Visible = FALSE). Если я использую QTP.Visible = TRUE - проблема не возникает. Что это за проблема!!!

StackTrace:

Object reference not set to an instance of an object.
   at OracleInternal.I18N.Conv.GetMaxBytesPerChar(Int32 charsetId)
   at OracleInternal.ServiceObjects.OracleConnectionImpl.Connect(ConnectionString cs, Boolean bOpenEndUserSession)
   at OracleInternal.ConnectionPool.PoolManager`3.CreateNewPR(Int32 reqCount, Boolean bForPoolPopulation, ConnectionString csWithDiffOrNewPwd)
   at OracleInternal.ConnectionPool.PoolManager`3.Get(ConnectionString csWithDiffOrNewPwd)
   at OracleInternal.ConnectionPool.OraclePoolManager.Get(ConnectionString csWithNewPassword)
   at OracleInternal.ConnectionPool.OracleConnectionDispenser`3.Get(ConnectionString cs, PM conPM, ConnectionString pmCS, SecureString securedPassword, SecureString securedProxyPassword)
   at Oracle.ManagedDataAccess.Client.OracleConnection.Open()
   at myDBWrapper.Utility.DBUtil.OpenConnection()
21.02.2015

  • Пожалуйста, покажите полную трассировку стека. 22.02.2015
  • @OldProgrammer, спасибо за проверку. добавлена ​​трассировка стека. 22.02.2015
  • @OldProgrammer, в качестве дополнительной информации, QTP - это инструмент автоматизации. он может импортировать .net dll и использовать его методы. В графическом режиме работает отлично. В режиме без графического интерфейса выдает ошибку. происходит как на 64-битных, так и на 32-битных машинах. все остальные dll работают в режиме без графического интерфейса. Я хотел бы предоставить любую информацию, необходимую для решения этой проблемы. 22.02.2015
  • @TheBlastOne, спасибо, что проверили это. Да, я также упомянул то же самое в своем вопросе - в трассировке стека. 26.04.2015
  • Мне кажется, что это ошибка в OracleInternal.I18N... Я не знаю, можно ли с этим что-то сделать. 26.04.2015
  • Возможный обходной путь: начните скрывать, отобразите только для подключения, а затем снова отобразите. Кроме того, я думаю, вы можете настроить qtp так, чтобы он был сведен к минимуму и все еще имел видимый статус. 26.04.2015
  • @TheBlastOne, проблема в том, что у меня есть driver.vbs, который использует AOM QTP - он должен скрывать QTP во время запуска. Как только QTP вызывается, он начинает выполнять все действия. Существует глобальный объект, инициализируемый с помощью dotnetfactory с dll с помощью QTP после вызова QTP. Если мне нужно сделать так, чтобы он снова не скрывался, мне нужна отдельная функция в QTP, чтобы сделать это, поскольку driver.vbs не может справиться с этим, поскольку это отдельный процесс. В настоящее время я не использую скрытый режим из-за этой проблемы. Но я хотел бы использовать скрытый режим для повышения общей производительности. Спасибо за проверку. 27.04.2015
  • Qtp может найти свой собственный экземпляр AOM (есть только один) и переключить видимость из кода сценария действия, не так ли? 27.04.2015
  • @TheBlastOne, да, это выполнимо. 27.04.2015
  • Извините, если я что-то упустил, но UFT не поддерживает VB.NET. Вместо этого он использует VBScript. И в моем проекте я использую объект Adodb для подключения к базе данных Oracle из VBScript. 05.11.2016

Ответы:


1

Потому что это похоже на VB.NET. У вас есть этот код в форме загрузки? Это событие непредсказуемо, если вы не показываете форму.

30.04.2015

2

Вы пробовали соединение с оракулом, используя объект соединения ADOB? вам необходимо установить драйвер Oracle, и он поможет вам подключиться к БД, создав объект подключения ADOB

30.04.2015
  • Вероятно, это должен быть комментарий, а не ответ 30.04.2015

  • 3

    Попробуй это

    conn = New Oracle.ManagedDataAccess.Client.OracleConnection(ConnectionString)
    
    23.12.2015
    Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..