exec

(Не рекомендуемый), Выполняют SQL-оператор и открытый курсор

exec функция не рекомендуется. Для SQL-операторов, которые возвращают данные, используйте fetch функционируйте или select функцию вместо этого. Для других SQL-операторов используйте execute функцию вместо этого. Для получения дополнительной информации см. Вопросы совместимости.

Функциональность курсора с возможностью прокрутки не имеет никакой замены.

Описание

пример

curs = exec(conn,sqlquery) создает cursor объект после выполнения SQL-оператора sqlquery для соединения с базой данных conn.

curs = exec(conn,sqlquery,Name,Value) задает опции с помощью одного или нескольких аргументов пары "имя-значение". Например, 'MaxRows',10 ограничивает количество строк, чтобы возвратиться к 10 перед выполнением SQL-запроса.

curs = exec(conn,sqlquery,qTimeOut) использует значение тайм-аута qTimeOut для выполнения SQL-запроса.

Примеры

свернуть все

Используйте нативную связь ODBC, чтобы импортировать данные о продукте от базы данных Microsoft® SQL Server® в MATLAB®. Затем определите самую высокую себестоимость единицы продукции среди продуктов.

Создайте соединение с базой данных ODBC к базе данных Microsoft SQL Server с аутентификацией Windows®. Задайте пустое имя пользователя и пароль. База данных содержит таблицу productTable.

datasource = 'MS SQL Server Auth';
conn = database(datasource,'','');

Проверяйте соединение с базой данных. Если Message свойство пусто, связь успешна.

conn.Message
ans =

     []

Выберите все данные из таблицы productTable использование connection объект. Присвойте SQL SELECT оператор к переменной sqlquery. cursor объект содержит выполняемый SQL-запрос.

sqlquery = 'SELECT * FROM productTable';
curs = exec(conn,sqlquery)
curs = 

   cursor with properties:

         Data: 0
     RowLimit: 0
     SQLQuery: 'SELECT * FROM productTable'
      Message: []
         Type: 'ODBCCursor Object'
    Statement: [1×1 database.internal.ODBCStatementHandle]

Для связи ODBC, Type свойство содержит ODBCCursor Object. Для связей JDBC это свойство содержит Database Cursor Object.

Импортируйте данные из таблицы в MATLAB.

curs = fetch(curs);
data = curs.Data;

Определите самую высокую себестоимость единицы продукции в таблице.

max(data.unitCost)
ans =

    24

После того, как вы закончили работать с cursor объект, закройте его. Закройте соединение с базой данных.

close(curs)
close(conn)

Входные параметры

свернуть все

Соединение с базой данных в виде ODBC connection возразите или connection JDBC объект создал использование database функция.

SQL-оператор в виде вектора символов или строкового скаляра. SQL-оператор может быть любым допустимым SQL-оператором, включая вложенные запросы. SQL-оператор может быть хранимой процедурой, такой как {call sp_name (parm1,parm2,...)}. Для хранимых процедур, которые возвращают один или несколько наборов результатов, использовать exec функция. Для процедур, которые возвращают выходные аргументы, использовать runstoredprocedure.

Для получения информации о языке SQL-запроса см. Пример по SQL.

Типы данных: char | string

Значение тайм-аута в виде числового скаляра, обозначающего максимальное количество времени, в секундах, том exec попытки выполнить SQL-оператор sqlquery.

Типы данных: double

Аргументы в виде пар имя-значение

Задайте дополнительные разделенные запятой пары Name,Value аргументы. Name имя аргумента и Value соответствующее значение. Name должен появиться в кавычках. Вы можете задать несколько аргументов в виде пар имен и значений в любом порядке, например: Name1, Value1, ..., NameN, ValueN.

Пример: curs = exec(conn,sqlquery,'MaxRows',rowlimit);

Максимальное количество строк, чтобы возвратиться прежде, чем выполнить SQL-запрос в виде разделенной запятой пары, состоящей из 'MaxRows' и положительный числовой скаляр. По умолчанию, exec функция возвращает все строки в выполняемый SQL-запрос. Используйте этот аргумент пары "имя-значение", чтобы ограничить количество строк, импортированных в MATLAB из выполнения SQL-запроса. Для получения дополнительной информации об этой опции и других опциях управления памятью, смотрите управление памятью Импорта Данных.

Типы данных: double

Тип курсора в виде разделенной запятой пары, состоящей из 'CursorType' и одно из значений в этой таблице.

ЗначениеОписание

'forward_only'

Создайте основной курсор.

'scrollable'

Создайте курсор с возможностью прокрутки.

Выходные аргументы

свернуть все

Курсор базы данных, возвращенный как cursor объект.

Ограничения

Аргумент пары "имя-значение" 'MaxRows' имеет эти ограничения:

  • Если вы используете Microsoft Access™, нативный интерфейс ODBC не поддерживается.

  • Не вся поддержка драйверов базы данных, определяющая максимальный номер строк перед выполнением запросов. Для неподдерживаемого драйвера измените свой SQL-запрос, чтобы ограничить максимальное количество строк, чтобы возвратиться. Синтаксис SQL меняется в зависимости от драйвера. Для получения дополнительной информации консультируйтесь с документацией драйвера.

Советы

  • Порядок записей в вашей базе данных не остается постоянным. Сортировка данных с помощью SQL ORDER BY команда в вашем sqlquery оператор.

  • Для Microsoft Excel®, таблиц в sqlquery рабочие листы Excel. По умолчанию некоторые имена рабочего листа включают $ символ. Чтобы выбрать данные из рабочего листа с этим форматом имени, используйте SQL-оператор формы SELECT * FROM "Sheet1$"(или 'Sheet1$').

  • Прежде чем вы измените таблицы базы данных, гарантируете, что база данных не открыта для редактирования. При попытке отредактировать базу данных, в то время как это открыто, вы получаете эту ошибку MATLAB:

    [Vendor][ODBC Driver] The database engine could not lock 
    table 'TableName' because it is already in use by 
    another person or process.
  • Система управления базами данных PostgreSQL поддерживает многомерные поля, но SQL SELECT операторы перестали работать при получении этих полей, если вы не задаете индекс.

  • Некоторые базы данных требуют, чтобы вы включали символ, такой как #, до и после даты в запросе, можно следующим образом:

    curs = exec(conn,'SELECT * FROM mydb WHERE mydate > #03/05/2005#')

Альтернативная функциональность

Приложение

exec функция выполняет SQL-операторы с помощью командной строки. Чтобы выполнить SQL-операторы в интерактивном режиме, используйте приложение Database Explorer.

Вопросы совместимости

развернуть все

Не рекомендуемый запуск в R2018b

Представлено до R2006a