SQL Serverデータベースで文字列を検索するにはどうすればよいですか?


121

それが可能かどうかはわかりますが、方法はわかりません。

特定の文字列に関するすべての言及について、SQL Serverデータベースを検索する必要があります。

例:すべてのテーブル、ビュー、関数、ストアドプロシージャなどを検索して、文字列 "tblEmployes"(テーブル内のデータではない)を探します。

これが必要な理由の1つは、作成された余分なデータテーブルをいくつか削除したいのですが、プロシージャまたは関数のどこかで使用されているのではないかと心配です。



1
これが誰かに役立つことを願っています、stackoverflow.com
questions / 13174627 /…

回答:


155

これにより、特定のデータベースのすべてのテーブルのすべての列が検索されます。検索するデータベースにストアドプロシージャを作成します。

SQL Serverに関する10の質問とその回答

CREATE PROCEDURE FindMyData_String
    @DataToFind NVARCHAR(4000),
    @ExactMatch BIT = 0
AS
SET NOCOUNT ON

DECLARE @Temp TABLE(RowId INT IDENTITY(1,1), SchemaName sysname, TableName sysname, ColumnName SysName, DataType VARCHAR(100), DataFound BIT)

    INSERT  INTO @Temp(TableName,SchemaName, ColumnName, DataType)
    SELECT  C.Table_Name,C.TABLE_SCHEMA, C.Column_Name, C.Data_Type
    FROM    Information_Schema.Columns AS C
            INNER Join Information_Schema.Tables AS T
                ON C.Table_Name = T.Table_Name
        AND C.TABLE_SCHEMA = T.TABLE_SCHEMA
    WHERE   Table_Type = 'Base Table'
            And Data_Type In ('ntext','text','nvarchar','nchar','varchar','char')


DECLARE @i INT
DECLARE @MAX INT
DECLARE @TableName sysname
DECLARE @ColumnName sysname
DECLARE @SchemaName sysname
DECLARE @SQL NVARCHAR(4000)
DECLARE @PARAMETERS NVARCHAR(4000)
DECLARE @DataExists BIT
DECLARE @SQLTemplate NVARCHAR(4000)

SELECT  @SQLTemplate = CASE WHEN @ExactMatch = 1
                            THEN 'If Exists(Select *
                                          From   ReplaceTableName
                                          Where  Convert(nVarChar(4000), [ReplaceColumnName])
                                                       = ''' + @DataToFind + '''
                                          )
                                     Set @DataExists = 1
                                 Else
                                     Set @DataExists = 0'
                            ELSE 'If Exists(Select *
                                          From   ReplaceTableName
                                          Where  Convert(nVarChar(4000), [ReplaceColumnName])
                                                       Like ''%' + @DataToFind + '%''
                                          )
                                     Set @DataExists = 1
                                 Else
                                     Set @DataExists = 0'
                            END,
        @PARAMETERS = '@DataExists Bit OUTPUT',
        @i = 1

SELECT @i = 1, @MAX = MAX(RowId)
FROM   @Temp

WHILE @i <= @MAX
    BEGIN
        SELECT  @SQL = REPLACE(REPLACE(@SQLTemplate, 'ReplaceTableName', QUOTENAME(SchemaName) + '.' + QUOTENAME(TableName)), 'ReplaceColumnName', ColumnName)
        FROM    @Temp
        WHERE   RowId = @i


        PRINT @SQL
        EXEC SP_EXECUTESQL @SQL, @PARAMETERS, @DataExists = @DataExists OUTPUT

        IF @DataExists =1
            UPDATE @Temp SET DataFound = 1 WHERE RowId = @i

        SET @i = @i + 1
    END

SELECT  SchemaName,TableName, ColumnName
FROM    @Temp
WHERE   DataFound = 1
GO

実行するには、次のようにします。

exec FindMyData_string 'google', 0

それは驚くほどうまくいきます!!!


2番目のパラメーター "exactMatch = 0"はどういう意味ですか?
Junchen Liu 2015

スクリプトを見てみると、「value」または「%value%」を使用して文字列検索を行うかどうかを決定するために、caseステートメントで早い段階でチェックされるパラメータです
Chizzle

5
これは、最初に見つかった結果のみを返し、それ以外は何も返しません。データベース内の文字列のすべてのインスタンスを返す方法はありますか?
qroberts

1
このスクリプトはどこに保存する必要があり、ファイルを実行するためにどの拡張子が必要ですか?どこで実行しexec FindMyData_string 'google', 0ますか?
ブラック

一部のデータベースでは大文字と小文字が区別されないため、コードではINFORMATION_SCHEMA.COLUMNSを使用してください。そうでない場合、このスクリプトは「無効なオブジェクト名Information_Schema」エラーをスローします。
Fatih

59

データベースオブジェクト(テーブル、列、トリガーなど)を名前で検索する必要がある場合は、SQL検索と呼ばれる無料の Redgateソフトウェアツールをご覧ください。これは、データベース全体であらゆる種類の文字列を検索します。

ここに画像の説明を入力してください

ここに画像の説明を入力してください

これは、DBAやデータベース開発者にとって必要不可欠な優れたツールです。すでに、あらゆる種類の用途に使用することは絶対に無料であることを既に述べましたか?


25
良いツールですが、テーブル内の文字列を検索しません
JGilmartin

2
実際の行は検索しません
LearningJrDev

8
@LearningJrDev:いいえ - データベースオブジェクト(テーブル、ビュー、ストアドプロシージャなど)を名前で検索します。テーブルに含まれているデータは検索されませ
marc_s

4
@JGilmartin すべてのテーブル、ビュー、関数、ストアドプロシージャなどで文字列「tblEmployes」を検索したい質問の一部を引用させてください(テーブル内のデータではありません)テーブル内のデータを検索する場合は、T-SQL言語を使用します。このツールは、タスクのリファクタリングに最適です。
nemke

49

ApexSQL Searchを試すこともできます。これは、SQL Searchに似た無料のSSMSアドインです。

本当にSQLのみを使用したい場合は、次のスクリプトを試してください。

select
S.name as [Schema],
o.name as [Object],
o.type_desc as [Object_Type],
C.text as [Object_Definition]
from sys.all_objects O inner join sys.schemas S on O.schema_id = S.schema_id
inner join sys.syscomments C on O.object_id = C.id
where S.schema_id not in (3,4) -- avoid searching in sys and INFORMATION_SCHEMA schemas
and C.text like '%ICE_%'
order by [Schema]

4
ApexSQL Searchは素晴らしいです。このツールではスクリプトは必要ありません。
ミゲル

1
これは素晴らしいヘルプメイトです。感謝します:D
miniGweek

3
このクエリはオブジェクトのみを検索します。既存のすべてのテーブルで文字列を検索する必要があります。
セザール・レオン

ApexSQLはあなたにあなたのタイプを選択させる素晴らしい仕事をします
PeterFnet

プロシージャとビュー内で文字列を検索しようとしています。SQLは私にぴったりです。ありがとうございました。
MsTapp

20

データベース(小さい場合)をハードドライブ/デスクトップにエクスポートし、テキスト検索プログラムまたはテキストエディターで文字列検索を実行できます。


7
それは実際に悪い考えではありません。
Oliver Tappin

:)スクリプトも使用できます。しかし、優れたテキストエディタは、SQLコードに必要なほとんどすべてのことを実行できます。
IvanIvković2013年

1
そして、どのテキストエディタが多くのGBのデータを喜んでロードしますか?
Bohdan

おそらくありませんが、その場合はサードパーティのファイル検索エンジンを使用できます。また、ファイルを必要な数に分割できるアプリケーションがあります。
IvanIvković2016

1
MS SQLエクスポートはバイナリファイルであるため、提案した方法を使用してエクスポート、読み取り、または検索することはできません。
スペンサーヒル

17

SQL Serverで名前でテーブルを取得する場合:

SELECT *
FROM sys.Tables
WHERE name LIKE '%Employees%'

名前でストアドプロシージャを検索する場合:

SELECT name
FROM sys.objects
WHERE name = 'spName'

テーブルに関連するすべてのストアドプロシージャを取得するには:

----Option 1
SELECT DISTINCT so.name
FROM syscomments sc
INNER JOIN sysobjects so ON sc.id=so.id
WHERE sc.TEXT LIKE '%tablename%'
----Option 2
SELECT DISTINCT o.name, o.xtype
FROM syscomments c
INNER JOIN sysobjects o ON c.id=o.id
WHERE c.TEXT LIKE '%tablename%'

2
このクエリはオブジェクトのみを検索します。既存のすべてのテーブルで文字列を検索する必要があります。
セザール・レオン

6

このコードはプロシージャと関数を検索します、テーブル内は検索しません :)

SELECT name 
FROM   sys.all_objects 
WHERE  Object_definition(object_id) 
LIKE '%text%' 
ORDER BY name

4

あなたは出来る;

  1. データベースを単一のファイルにスクリプト化し、テキストエディターを使用してそのファイルでtblEmployeesを検索します。でSQL Server Management Studioを(SSMS)、右のデータベース上でクリックすると、選択したスクリプトを生成します
  2. tblEmployeesを右クリックしてSSMSの「依存関係の表示」を使用し、依存している他のオブジェクトを確認します
  3. Redgate Softwareの SQL Search などの無料のサードパーティツールを使用して、すべてのデータベースオブジェクトを名前で検索し、コンテンツをキーワードで検索します。

#1いいですね。サーバーで実行できないのは、アクセス権がないためです。
bobetko

ありがとう。なぜ誰かが-1を与えたのかわかりません。直した。RedGateを試してみました...それは私が望むことを完全に行います。
bobetko

2

これは、すべてのデータベースで文字列を検索します。

declare @search_term varchar(max)
set @search_term = 'something'

select @search_term = 'use ? SET QUOTED_IDENTIFIER ON
select
    ''[''+db_name()+''].[''+c.name+''].[''+b.name+'']'' as [object],
    b.type_desc as [type],
    d.obj_def.value(''.'',''varchar(max)'') as [definition]
from (
    select distinct
        a.id
    from sys.syscomments a
    where a.[text] like ''%'+@search_term+'%''
) a
inner join sys.all_objects b
    on b.[object_id] = a.id
inner join sys.schemas c
    on c.[schema_id] = b.[schema_id]
cross apply (
    select
        [text()] = a1.[text]
    from sys.syscomments a1
    where a1.id = a.id
    order by a1.colid
    for xml path(''''), type
) d(obj_def)
where c.schema_id not in (3,4) -- avoid searching in sys and INFORMATION_SCHEMA schemas
    and db_id() not in (1,2,3,4) -- avoid sys databases'

if object_id('tempdb..#textsearch') is not null drop table #textsearch
create table #textsearch
(
    [object] varchar(300),
    [type] varchar(300),
    [definition] varchar(max)
)

insert #textsearch
exec sp_MSforeachdb @search_term

select *
from #textsearch
order by [object]

2

私のバージョン...

私はそれを「干し草の山の針」と名付けました。

列名などではなく、各行および各列で特定の値を検索します。

検索を実行します(もちろん最初の2つの変数の値を置き換えます):

DECLARE @SEARCH_DB VARCHAR(100)='REPLACE_WITH_YOUR_DB_NAME'
DECLARE @SEARCH_VALUE_LIKE NVARCHAR(100)=N'%REPLACE_WITH_SEARCH_STRING%'

SET NOCOUNT ON;
DECLARE col_cur CURSOR FOR
SELECT TABLE_CATALOG, TABLE_SCHEMA, TABLE_NAME, COLUMN_NAME, DATA_TYPE
FROM information_schema.columns WHERE TABLE_CATALOG=@SEARCH_DB AND DATA_TYPE NOT IN ('timestamp', 'datetime');

DECLARE @TOTAL int = (SELECT COUNT(*)
FROM information_schema.columns WHERE TABLE_CATALOG=@SEARCH_DB AND DATA_TYPE NOT IN ('timestamp', 'datetime'));


DECLARE @TABLE_CATALOG nvarchar(500), @TABLE_SCHEMA nvarchar(500), @TABLE_NAME nvarchar(500), @COLUMN_NAME nvarchar(500), @DATA_TYPE nvarchar(500);
DECLARE @SQL nvarchar(4000)='';

PRINT '-------- BEGIN SEARCH --------';
OPEN col_cur;

FETCH NEXT FROM col_cur INTO @TABLE_CATALOG, @TABLE_SCHEMA, @TABLE_NAME, @COLUMN_NAME, @DATA_TYPE;

BEGIN TRY DROP TABLE ##RESULTS; END TRY BEGIN CATCH END CATCH
CREATE TABLE ##RESULTS( TABLE_CATALOG nvarchar(500), TABLE_SCHEMA nvarchar(500), TABLE_NAME nvarchar(500), COLUMN_NAME nvarchar(500), DATA_TYPE nvarchar(500), RECORDS int)
DECLARE @SHOULD_CAST bit=0
DECLARE @i int =0
DECLARE @progress_sum bigint=0

WHILE @@FETCH_STATUS = 0
BEGIN
    -- PRINT '' + CAST(@i as varchar(100)) +' of ' + CAST(@TOTAL as varchar(100)) + '  ' + @TABLE_CATALOG+'.'+@TABLE_SCHEMA+'.'+@TABLE_NAME+': '+@COLUMN_NAME+' ('+@DATA_TYPE+')';

    SET @SHOULD_CAST = (SELECT CASE @DATA_TYPE
                                WHEN 'varchar' THEN 0
                                WHEN 'nvarchar' THEN 0
                                WHEN 'char' THEN 0
                                ELSE 1 END)

    SET @SQL='SELECT '''+@TABLE_CATALOG+''' catalog_name, '''+@TABLE_SCHEMA+''' schema_name, '''+@TABLE_NAME+''' table_name, '''+@COLUMN_NAME+''' column_name, '''+@DATA_TYPE+''' data_type, ' +
            +' COUNT(['+@COLUMN_NAME+']) records '+
            +' FROM '+@TABLE_CATALOG+'.'+@TABLE_SCHEMA+'.'+@TABLE_NAME +
            +' WHERE ' + CASE WHEN @SHOULD_CAST=1 THEN 'CAST(['+@COLUMN_NAME + '] as NVARCHAR(max)) ' ELSE ' ['+@COLUMN_NAME + '] ' END
            +' LIKE '''+ @SEARCH_VALUE_LIKE + ''' '

    -- PRINT @SQL;

    IF @i % 100 = 0
        BEGIN
            SET @progress_sum = (SELECT SUM(RECORDS) FROM ##RESULTS)
            PRINT CAST (@i as varchar(100)) +' of ' + CAST(@TOTAL as varchar(100)) +': '+ CAST (@progress_sum as varchar(100))
        END

    INSERT INTO ##RESULTS (TABLE_CATALOG, TABLE_SCHEMA, TABLE_NAME, COLUMN_NAME, DATA_TYPE, RECORDS)
    EXEC(@SQL)

    FETCH NEXT FROM col_cur INTO @TABLE_CATALOG, @TABLE_SCHEMA, @TABLE_NAME, @COLUMN_NAME, @DATA_TYPE;
    SET @i=@i+1
    -- IF @i > 1000
    --     BREAK
END
CLOSE col_cur;
DEALLOCATE col_cur;

SELECT * FROM ##RESULTS WHERE RECORDS>0;

次に、実行中であっても、別のウィンドウから結果を表示するには、次のコマンドを実行します。

DECLARE @SEARCH_VALUE_LIKE NVARCHAR(100)=N'%@FLEX@%'
SELECT * FROM ##RESULTS WHERE RECORDS>0;

SET NOCOUNT ON;
DECLARE col_cur CURSOR FOR
SELECT TABLE_CATALOG, TABLE_SCHEMA, TABLE_NAME, COLUMN_NAME, DATA_TYPE
FROM ##RESULTS WHERE RECORDS>0;

DECLARE @TABLE_CATALOG nvarchar(500), @TABLE_SCHEMA nvarchar(500), @TABLE_NAME nvarchar(500), @COLUMN_NAME nvarchar(500), @DATA_TYPE nvarchar(500);
DECLARE @SQL nvarchar(4000)='';

OPEN col_cur;

FETCH NEXT FROM col_cur INTO @TABLE_CATALOG, @TABLE_SCHEMA, @TABLE_NAME, @COLUMN_NAME, @DATA_TYPE;
DECLARE @i int =0
DECLARE @SHOULD_CAST bit=0

WHILE @@FETCH_STATUS = 0
BEGIN
    SET @SHOULD_CAST = (SELECT CASE @DATA_TYPE
                                WHEN 'varchar' THEN 0
                                WHEN 'nvarchar' THEN 0
                                WHEN 'char' THEN 0
                                ELSE 1 END)

    SET @SQL='SELECT '''+@TABLE_CATALOG+''' catalog_name, '''+@TABLE_SCHEMA+''' schema_name, '''+@TABLE_NAME+''' table_name, '''+@COLUMN_NAME+''' column_name, '''+@DATA_TYPE+''' data_type, ' +
            +' ['+@COLUMN_NAME+']'+
            +', * '
            +' FROM '+@TABLE_CATALOG+'.'+@TABLE_SCHEMA+'.'+@TABLE_NAME +
            +' WHERE ' + CASE WHEN @SHOULD_CAST=1 THEN 'CAST(['+@COLUMN_NAME + '] as NVARCHAR(max)) ' ELSE ' ['+@COLUMN_NAME + '] ' END
            +' LIKE '''+ @SEARCH_VALUE_LIKE + ''' '

    PRINT @SQL;

    EXEC(@SQL)

    FETCH NEXT FROM col_cur INTO @TABLE_CATALOG, @TABLE_SCHEMA, @TABLE_NAME, @COLUMN_NAME, @DATA_TYPE;
    SET @i=@i+1
    -- IF @i > 10
    --    BREAK
END
CLOSE col_cur;
DEALLOCATE col_cur;

それについて言及する人はほとんどいません:

  • ループをブロックする代わりにカーソルを使用する
  • 進捗状況を出力できます(必要に応じてコメントを外します)
  • 数回試行すると終了します(最後にIFのコメントを外します)
  • すべてのレコードを表示します
  • 必要に応じて微調整できます

免責事項:

  • 本番環境では実行しないでください。
  • それは遅いです。DBは他のサービス/ユーザがアクセスしている場合は、してください、すべての選択、特に動的選択のすべてのテーブル名の後に「WITH(NOLOCK)」追加して。
  • あらゆる種類のSQLインジェクションオプションを検証/保護するわけではありません。
  • DBが巨大な場合は、少しスリープする準備をして、数分後にクエリが強制終了されないようにします。
  • これは、ints / bigints / smallints / tinyintsを含むいくつかの値を文字列にキャストします。それらが必要ない場合は、スクリプトの上部にあるタイムスタンプと同じ除外リストに配置します。

2

データベースへのアクセス権が与えられましたが、クエリが格納されているテーブルへのアクセス権は与えられませんでした。

@marc_s answe rに触発され、HeidiSQLを確認しました MySQL、SQL Server、およびPostgreSQLを処理できるWindowsプログラムを。

データベースで文字列を検索することもできることがわかりました。

[検索]をクリックしてから、[サーバー上のテキストを検索]をクリックします

検索ツールを開きます。 DBが選択されていることを確認してください

各テーブルを検索し、テーブルごとに文字列を見つけた回数を示します。


1

すべてのストアドプロシージャ、ビュー、関数の内容は、sysCommentsテーブルのフィールドテキストに格納されています。すべてのオブジェクトの名前はテーブルsysObjectsに格納され、列はsysColumnsに格納されます。

この情報があれば、このコードを使用して、ビュー、ストアドプロシージャ、および関数のコンテンツで指定した単語を検索できます。

Select b.name from syscomments a
inner join sysobjects b on a.id = b.id
where text like '%tblEmployes%'

このクエリは、「tblEmployes」という単語を含むオブジェクトを提供します。

オブジェクトの名前で検索するには、次のコードを使用できます。

Select name from sysobjects
where name like  '%tblEmployes%'

最後に、「tblEmployes」という単語を含む少なくとも1つの列を持つオブジェクトを見つけるには、次のコードを使用できます。

Select b.name from syscolumns a inner join sysobjects b on a.id = b.id
where a.name like  '%tblEmployes%'

これら3つのクエリをunionと組み合わせることができます。

Select distinct b.name from syscomments a
inner join sysobjects b on a.id = b.id
where text like '%tblEmployes%'
union
Select distinct name from sysobjects
where name like  '%tblEmployes%'
union
Select distinct b.name from syscolumns a inner join sysobjects b on a.id = b.id
where a.name like  '%tblEmployes%'

このクエリを使用すると、コンテンツまたは名前に、または列として「tblEmployes」という単語を含むすべてのオブジェクトがあります。


0

これは、ユーザーl --''''''--------- '' '' '' '' '' ''によって送信されたものと同じスクリプトですが、大文字と小文字を区別するSQLで機能するように修正されていますインスタンス、およびその他のいくつかのマイナーな改善。

DROP PROCEDURE IF EXISTS dbo.spFind_Text_In_Database
GO

CREATE PROCEDURE dbo.spFind_Text_In_Database
    @strText_To_Find NVARCHAR(4000),
    @bitExact_Match BIT = 0
AS
SET NOCOUNT ON

DECLARE @Temp TABLE(RowId INT IDENTITY(1,1), SchemaName sysname, TableName sysname, ColumnName SysName, DataType VARCHAR(100), DataFound BIT)

    INSERT  INTO @Temp(TableName,SchemaName, ColumnName, DataType)
    SELECT  C.TABLE_NAME, C.TABLE_SCHEMA, C.COLUMN_NAME, C.DATA_TYPE
    FROM    INFORMATION_SCHEMA.COLUMNS AS C
            INNER Join INFORMATION_SCHEMA.TABLES AS T
                ON C.TABLE_NAME = T.TABLE_NAME
        AND C.TABLE_SCHEMA = T.TABLE_SCHEMA
    WHERE   TABLE_TYPE = 'BASE TABLE'
            And DATA_TYPE In ('ntext','text','nvarchar','nchar','varchar','char')


DECLARE @i INT
DECLARE @MAX INT
DECLARE @TableName sysname
DECLARE @ColumnName sysname
DECLARE @SchemaName sysname
DECLARE @SQL NVARCHAR(4000)
DECLARE @PARAMETERS NVARCHAR(4000)
DECLARE @DataExists BIT
DECLARE @SQLTemplate NVARCHAR(4000)

SELECT  @SQLTemplate = CASE WHEN @bitExact_Match = 1
                            THEN 'If Exists(Select *
                                          From   ReplaceTableName
                                          Where  Convert(nVarChar(4000), [ReplaceColumnName])
                                                       = ''' + @strText_To_Find + '''
                                          )
                                     Set @DataExists = 1
                                 Else
                                     Set @DataExists = 0'
                            ELSE 'If Exists(Select *
                                          From   ReplaceTableName
                                          Where  Convert(nVarChar(4000), [ReplaceColumnName])
                                                       Like ''%' + @strText_To_Find + '%''
                                          )
                                     Set @DataExists = 1
                                 Else
                                     Set @DataExists = 0'
                            END,
        @PARAMETERS = '@DataExists Bit OUTPUT',
        @i = 1

SELECT @i = 1, @MAX = MAX(RowId)
FROM   @Temp

WHILE @i <= @MAX
    BEGIN
        SELECT  @SQL = REPLACE(REPLACE(@SQLTemplate, 'ReplaceTableName', QUOTENAME(SchemaName) + '.' + QUOTENAME(TableName)), 'ReplaceColumnName', ColumnName)
        FROM    @Temp
        WHERE   RowId = @i


        PRINT @SQL
        EXEC sp_executesql @SQL, @PARAMETERS, @DataExists = @DataExists OUTPUT

        IF @DataExists =1
            UPDATE @Temp SET DataFound = 1 WHERE RowId = @i

        SET @i = @i + 1
    END

SELECT  SchemaName,TableName, ColumnName
FROM    @Temp
WHERE   DataFound = 1
GO

0

SQLデータベースオブジェクトの検索は、SQL Server Management Studio(SSMS)で次のメソッドを使用して、SSMSオブジェクト検索:オブジェクトエクスプローラーの詳細またはT-SQLスクリプトで説明されています。


0

これは、FMDBライブラリを使用してSwiftでデータベースを検索する方法です。

まず、このリンクに移動して、プロジェクトにこれを追加します:FMDB。それが終わったら、次のようにします。たとえば、Personというテーブルがあり、firstNameとsecondNameがあり、名でデータを検索したい場合は、次のコードを使用します。

    func loadDataByfirstName(firstName : String, completion: @escaping CompletionHandler){
    if isDatabaseOpened {
        let query = "select * from Person where firstName like '\(firstName)'"
        do {
            let results = try database.executeQuery(query, values: [firstName])
            while results.next() {
                let firstName = results.string(forColumn: "firstName") ?? ""
                let lastName = results.string(forColumn: "lastName") ?? ""
                let newPerson = Person(firstName: firstName, lastName: lastName)
                self.persons.append(newPerson)
            }
            completion(true)
        }catch let err {
            completion(false)
            print(err.localizedDescription)
        }
        database.close()
    }
}

次に、ViewControllerでこれを書き込んで、探している人物の詳細を見つけます。

  override func viewWillAppear(_ animated: Bool) {
     super.viewWillAppear(animated)
      SQLManager.instance.openDatabase { (success) in
        if success {
            SQLManager.instance.loadDataByfirstName(firstName: "Hardi") { (success) in
                if success {
                    // You have your data Here
                }
            }
        }
    }
}

この答え(SQLiteについて)は質問に答えません。問題はSQL Serverに関するものでした(Microsoftの製品ですが、そのような製品の一般的な名前を選択したことに対する非難もあります)。GitHubページから:FMDB v2.7 ...これはSQLiteのObjective-Cラッパーです
Peter Mortensen

0

検索したいものがある場所を見つけたい場合は、これを使用します。

DECLARE @search_string    varchar(200)
    SET @search_string = '%myString%'

    SELECT DISTINCT
           o.name AS Object_Name,
           o.type_desc,
           m.definition
      FROM sys.sql_modules m
           INNER JOIN
           sys.objects o
             ON m.object_id = o.object_id
     WHERE m.definition Like @search_string;
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.