Not
Bu sayfaya erişim yetkilendirme gerektiriyor. Oturum açmayı veya dizinleri değiştirmeyi deneyebilirsiniz.
Bu sayfaya erişim yetkilendirme gerektiriyor. Dizinleri değiştirmeyi deneyebilirsiniz.
Şunlar için geçerlidir:SQL Server
Azure SQL Database
Azure SQL Managed Instance
Azure Synapse Analytics
Analitik Platform Sistemi (PDW)
Microsoft Fabric'te SQL veritabanı
sqlcmd yardımcı programı çeşitli modlar aracılığıyla Transact-SQL deyimleri, sistem yordamlarını ve betik dosyalarını girmenizi sağlar:
- Komut isteminde.
- SQLCMD modunda Sorgu Düzenleyicisi.
- Bir Windows script dosyasında.
- SQL Server Agent işindeki bir işletim sistemi (
cmd.exe) iş adımı.
Note
Microsoft Entra ID, Azure Active Directory (Azure AD) içinyeni ad olsa da, mevcut ortamların kesintiye uğramasını önlemek için Azure AD yine de kullanıcı arabirimi alanları, bağlantı sağlayıcıları, hata kodları ve cmdlet'ler gibi sabit kodlanmış bazı öğelerde kalır. Bu makalede, iki ad birbirinin yerine kullanılabilir.
sqlcmd varyantları
sqlcmd'nin iki çeşidi vardır:
sqlcmd (Go):
go-mssqldbtabanlı sqlcmd, bazen go-sqlcmd olarak adlandırılır. Bu sürüm, SQL Server'ı bağımsız olarak indirebileceğiniz tek başına bir araçtır. Windows, macOS, Linux ve kapsayıcılarda çalışır.sqlcmd (ODBC): SQL Server veya Microsoft Komut Satırı Yardımcı Programları ile kullanılabilen platforma hizalanmış, ODBC tabanlı sqlcmd ve Linux'ta paketin
mssql-toolsbir parçası. Ayrıca Windows, macOS, Linux ve kapsayıcılarda da çalışır.
Sisteminizde hangi sqlcmd değişkeninin ve sürümünün yüklü olduğunu öğrenmek için bkz. Sqlcmd yardımcı programının yüklü sürümünü denetleme.
sqlcmd'yi alma hakkında bilgi için bkz. sqlcmd yardımcı programını indirme ve yükleme.
TDS 8.0 desteği
SQL Server 2025 (17.x), sqlcmd yardımcı programı için TDS 8.0 desteği sağlar.
Syntax
Usage:
sqlcmd [flags]
sqlcmd [command]
Examples:
# Install/Create, Query, Uninstall SQL Server
sqlcmd create mssql --accept-eula --using https://aka.ms/AdventureWorksLT.bak
sqlcmd open ads
sqlcmd query "SELECT @@version"
sqlcmd delete
# View configuration information and connection strings
sqlcmd config view
sqlcmd config cs
Available Commands:
completion Generate the autocompletion script for the specified shell
config Modify sqlconfig files using subcommands like "sqlcmd config use-context mssql"
create Install/Create SQL Server, Azure SQL, and Tools
delete Uninstall/Delete the current context
help Help about any command
open Open tools (e.g ADS) for current context
query Run a query against the current context
start Start current context
stop Stop current context
Flags:
-?, --? help for backwards compatibility flags (-S, -U, -E etc.)
-h, --help help for sqlcmd
--sqlconfig string configuration file (default "/Users/<currentUser>/.sqlcmd/sqlconfig")
--verbosity int log level, error=0, warn=1, info=2, debug=3, trace=4 (default 2)
--version print version of sqlcmd
Use "sqlcmd [command] --help" for more information about a command.
sqlcmd söz dizimi ve kullanımı hakkında daha ayrıntılı bilgi için bkz. odbc sqlcmd söz dizimi .
sqlcmd'den işlevselliği bozabilecek değişiklikler (ODBC)
sqlcmd (Go) yardımcı programındaki çeşitli anahtarlar ve davranışlar değiştirilmiştir. Geriye dönük uyumluluk için eksik bayrakların en güncel listesi için Geri uyumluluk bayraklarının uygulanmasına öncelik verilmesi konulu GitHub tartışmasını ziyaret edin.
sqlcmd (Go) önceki sürümlerinde
-Panahtarı geçici olarak kaldırılmıştır ve SQL Server Kimlik Doğrulaması parolaları yalnızca şu mekanizmalar aracılığıyla sağlanabilirdi:-
SQLCMDPASSWORDortam değişkeni -
:CONNECTkomutu - İstendiğinde, kullanıcı bağlantıyı tamamlamak için parolayı yazabilir
-
-r, bir0veya1bağımsız değişkeni gerektirir.-Ranahtarı kaldırılır.-Ianahtarı kaldırılır. Tırnaklı tanımlayıcı davranışını devre dışı bırakmak için betiklerinizeSET QUOTED IDENTIFIER OFFekleyin.-N,true,falseveyadisabledize değerlerinden biri olabilecek bir dize değeri alır ve şifreleme seçimini belirtir. (defaultparametresinin atlanmasıyla aynıdır)-
-Nve-Csağlanmazsa, sqlcmd sunucu sertifikasını doğrulamadan sunucuyla kimlik doğrulaması müzakeresi yapar. -
-Nsağlanmışsa ancak-Csağlanmadıysa, sqlcmd sunucu sertifikasının doğrulanması gerekir. Şifreleme içinfalsedeğeri yine de oturum açma paketinin şifrelenmesini sağlayabilir. - Hem
-Nhem de-Csağlanırsa, sqlcmd şifreleme anlaşması için değerlerini kullanır. - İstemci/sunucu şifreleme anlaşması hakkında daha fazla bilgi MS-TDS PRELOGINbulunabilir.
Important
SQL Server 2025'te (17.x),
-N(içino),optional(içinm, varsayılan) veyamandatory(içins) olabilirstrict. Eğer siz-Neklemezseniz,-Nm(mandatoryiçin) varsayılandır. Bu, SQL Server 2022 (16.x) ve önceki sürümlerinden itibaren önemli bir değişikliktir.-
-uOluşturulan Unicode çıkış dosyasında UTF-16 Little-Endian Byte-order işareti (BOM) yazılmıştır.Bazı veri türleri için sütun başlıklarının hizalaması gibi, uyumluluğu
OSQLsürdürmek için tutulan bazı davranışlar değişmiş olabilir.tüm komutlar,
EXITbile tek satıra sığmalıdır. Etkileşimli mod, komutlar için açık parantezleri veya tırnak işaretlerini kontrol etmez ve ardışık satırlar için uyarıda bulunmaz. Bu davranış,EXIT(query)tarafından çalıştırılan sorgunun birden çok satıra yayılmasına olanak tanıyan ODBC sürümünden farklıdır.
sqlcmd (Go) yardımcı programındaki bağlantılar TCP bağlantılarıyla sınırlıdır. Şu anda adlandırılmış kanallar go-mssqldb sürücüsünde desteklenmiyor.
Enhancements
:Connect, Azure SQL Veritabanı için kimlik doğrulama yöntemlerinden birini seçmek amacıyla isteğe bağlı-Gparametresine sahiptir -SqlAuthentication,ActiveDirectoryDefault,ActiveDirectoryIntegrated,ActiveDirectoryServicePrincipal,ActiveDirectoryManagedIdentity,ActiveDirectoryPassword. Daha fazla bilgi için bkz. sqlcmd'de Microsoft Entra Kimliği ile kimlik doğrulaması yapma.-Gsağlanmazsa,-Ukullanıcı adı parametresinin varlığına bağlı olarak Tümleşik güvenlik veya SQL Server kimlik doğrulaması kullanılır.--driver-logging-levelkomut satırı parametresi,go-mssqldbsürücüden izlemeleri görmenize olanak tanır. Tüm izleri görmek için64kullanın.sqlcmd (Go), dikey biçim kullanarak sonuçları yazdırabilir.
-F verticalAyarlamak için komut satırı anahtarını kullanın.SQLCMDFORMATbetik değişkeni de bunu denetler.Note
Bu,
-File birlikte sertifikada konak adını belirtmek için kullanılan sqlcmd (ODBC) anahtarından farklıdır.
Komut satırı seçenekleri
Aşağıdaki tabloda sqlcmd'de kullanılabilen komut satırı seçenekleri ve bunların desteklediği işletim sistemleri listelenmiştir.
Oturum açmayla ilgili seçenekler
-A
Şunlar için geçerlidir: yalnızca Windows. Linux ve macOS desteklenmez.
Ayrılmış yönetici bağlantısıyla (DAC) SQL Server'da oturum açar. Bu tür bir bağlantı, sunucu sorunlarını gidermek için kullanılır. Bu bağlantı yalnızca DAC destekleyen sunucu bilgisayarlarıyla çalışır. DAC kullanılamıyorsa, sqlcmd bir hata iletisi oluşturur ve sonra çıkar. DAC hakkında daha fazla bilgi için bkz. Veritabanı yöneticileri için tanılama bağlantısı.
-A seçeneği -G seçeneğiyle desteklenmez.
-Akullanarak Azure SQL Veritabanı'na bağlanırken mantıksal SQL sunucusunda yönetici olmanız gerekir. DAC, Microsoft Entra yöneticisi tarafından kullanılamaz.
Note
macOS veya Linux üzerinde ayrılmış yönetici bağlantısı (DAC) oluşturma hakkında bilgi için bkz. Programlama Yönergeleri.
-C
Bu seçenek istemci tarafından sunucu sertifikasına doğrulama olmadan örtük olarak güvenecek şekilde yapılandırmak için kullanılır. Bu seçenek, TRUSTSERVERCERTIFICATE = trueADO.NET seçeneğine eşdeğerdir.
sqlcmd (Go) yardımcı programı için aşağıdaki koşullar da geçerlidir:
-
-Nve-Csağlanmazsa, sqlcmd sunucu sertifikasını doğrulamadan sunucuyla kimlik doğrulaması müzakeresi yapar. -
-Nsağlanmışsa ancak-Csağlanmadıysa, sqlcmd sunucu sertifikasının doğrulanması gerekir. Şifreleme içinfalsedeğeri yine de oturum açma paketinin şifrelenmesini sağlayabilir. - Hem
-Nhem de-Csağlanırsa, sqlcmd şifreleme anlaşması için değerlerini kullanır.
-d db_name
USE <db_name>sqlcmd'i başlattığınızda bir deyimi oluşturur. Bu seçenek, sqlcmd betik oluşturma değişkenini SQLCMDDBNAMEayarlar. Bu parametre ilk veritabanını belirtir. Varsayılan, giriş bilgilerinizin varsayılan veritabanı özelliğidir. Veritabanı mevcut değilse bir hata mesajı oluşturulur ve sqlcmd kapanır.
-D
-S için sağlanan sunucu adını konak adı yerine DSN olarak yorumlar. Daha fazla bilgi için bkz. sqlcmd ve bcp'de DSN desteği.
Note
-D seçeneği yalnızca Linux ve macOS istemcilerinde kullanılabilir. Windows istemcilerinde, artık kullanılmayan ve dikkate alınmayan eski bir seçeneği ifade eder.
-l oturum_zaman_aşımı
Bir sunucuya bağlanmaya çalıştığınızda sqlcmd ODBC sürücüsünde oturum açma işleminin zaman aşımına uğramasına önce geçmesi gereken saniye sayısını belirtir. Bu seçenek, sqlcmd betik oluşturma değişkenini SQLCMDLOGINTIMEOUTayarlar.
sqlcmd'e oturum açmak için varsayılan zaman aşımı 8 saniyedir. Azure SQL Veritabanı veya Azure Synapse Analytics'e bağlanma ve Microsoft Entra Id kullanarak kimlik doğrulaması seçeneği kullanıldığında -G en az 30 saniyelik bir zaman aşımı değeri önerilir. Oturum açma zaman aşımı, 0 ile 65534arasında bir sayı olmalıdır. Sağlanan değer sayısal değilse veya bu aralığa girmiyorsa sqlcmd bir hata iletisi oluşturur.
0 değeri zaman aşımının sonsuz olacağını belirtir.
-E
SQL Server'da oturum açmak için kullanıcı adı ve parola kullanmak yerine güvenilir bir bağlantı kullanır. Varsayılan olarak, -E belirtilmediğinde sqlcmd güvenilen bağlantı seçeneğini kullanır.
-E seçeneği, SQLCMDPASSWORDgibi olası kullanıcı adı ve parola ortam değişkeni ayarlarını yoksayar.
-E seçeneği -U seçeneği veya -P seçeneğiyle birlikte kullanılırsa bir hata iletisi oluşturulur.
Note
Linux veya macOS istemcisinden tümleşik kimlik doğrulaması kullanan güvenilir bağlantılar oluşturma hakkında daha fazla bilgi için bkz. Tümleşik Kimlik Doğrulaması Kullanma.
-g
Sütun Şifrelemesi ayarını Enabledolarak ayarlar. Daha fazla bilgi için bkz. Always Encrypted . Yalnızca Windows Sertifika Deposu'nda depolanan ana anahtarlar desteklenir.
-g seçeneği için en az sqlcmd sürümü 13.1gerekir. Sürümünüzü belirlemek için sqlcmd -?'ı yürütün.
-G
Bu seçenek istemci tarafından Azure SQL Veritabanı'na veya Azure Synapse Analytics'e bağlanırken kullanıcının Kimliğinin Microsoft Entra kimlik doğrulamasıyla doğrulandığını belirtmek için kullanılır. Bu seçenek, sqlcmd betik oluşturma değişkenini SQLCMDUSEAAD = trueayarlar.
-G seçeneği için en az sqlcmd sürümü 13.1gerekir. Sürümünüzü belirlemek için sqlcmd -?'ı yürütün. Daha fazla bilgi için bkz. Azure SQL için Microsoft Entra kimlik doğrulaması.
-A seçeneği -G seçeneğiyle desteklenmez.
-G seçeneği yalnızca Azure SQL Veritabanı ve Azure Synapse Analytics için geçerlidir.
Microsoft Entra etkileşimli kimlik doğrulaması şu anda Linux veya macOS'ta desteklenmiyor. Microsoft Entra tümleşik kimlik doğrulaması, SQL Server sürüm 17.6.1 veya üzeri için ODBC Sürücüsünü İndirmeyi ve düzgün yapılandırılmış bir Kerberos ortamını gerektirir.
Microsoft Entra kimlik doğrulaması hakkında daha fazla bilgi için bkz. sqlcmd'de Microsoft Entra Kimliği ile kimlik doğrulama.
-H workstation_name
İş istasyonu adı. Bu seçenek, sqlcmd betik oluşturma değişkenini SQLCMDWORKSTATIONayarlar. İş istasyonu adı, hostname katalog görünümünün sys.sysprocesses sütununda listelenir ve sp_whosaklı yordamı kullanılarak döndürülebilir. Bu seçenek belirtilmezse, varsayılan değer geçerli bilgisayar adıdır. Bu ad, farklı sqlcmd oturumlarını tanımlamak için kullanılabilir.
-j
Ham hata iletilerini ekrana yazdırır.
-K application_intent (uygulama amacı)
Sunucuya bağlanırken uygulama iş yükü türünü bildirir. Şu anda desteklenen tek değer ReadOnly.
-K belirtilmezse, sqlcmd bir kullanılabilirlik grubundaki ikincil çoğaltmaya bağlantıyı desteklemez. Daha fazla bilgi için bkz. Always On kullanılabilirlik grubunun ikincil çoğaltmasına salt okunur iş yükünü boşaltma.
Note
-K SUSE Linux Enterprise Server'da (SLES) desteklenmez. Ancak ApplicationIntent=ReadOnly geçirilen bir DSN dosyasında anahtar sözcüğünü belirtebilirsiniz. Daha fazla bilgi için bu makalenin devamında sqlcmd ve bcp'de DSN Desteği bölümüne bakın.
Daha fazla bilgi için bkz. Linux ve macOS'ta yüksek kullanılabilirlik ve olağanüstü durum kurtarma.
-M multisubnet_failover
SQL Server kullanılabilirlik grubu dinleyicisine ya da bir SQL Server Yük Devretme Kümesi Örneğine bağlanırken her zaman -M ifadesini belirtin.
-M, (şu anda) etkin sunucuya daha hızlı algılama ve bağlantı sağlar.
-M belirtilmezse -M kapalıdır.
Daha fazla bilgi için bakınız:
- Always On kullanılabilirlik grubu dinleyicisine bağlanma
- Always On kullanılabilirlik gruplarının oluşturulması ve yapılandırılması için başvuru
- Yük Devretme Kümelemesi ve Her Zaman Açık Kullanılabilirlik Grupları (SQL Server)
- Salt okunur iş yükünü Always On yüksek erişim grubunun ikincil replikasına devretme
Note
-M SUSE Linux Enterprise Server'da (SLES) desteklenmez. Ancak MultiSubnetFailover=Yes geçirilen bir DSN dosyasında anahtar sözcüğünü belirtebilirsiniz. Daha fazla bilgi için bu makalenin devamında sqlcmd ve bcp'de DSN Desteği bölümüne bakın.
Daha fazla bilgi için bkz. Linux ve macOS'ta yüksek kullanılabilirlik ve olağanüstü durum kurtarma.
-N[s|m|o]
Bu seçenek, istemci tarafından şifreli bir bağlantı istemek için kullanılır.
-N (için o), optional, m (için mandatory, varsayılan) veya s (için strict) olabilir. Eğer siz -N eklemezseniz, -Nm (mandatory için) varsayılandır. Bu, -No'nin varsayılan olduğu SQL Server 2022 (16.x) ve önceki sürümlerinden farklı bir değişikliktir.
sqlcmd (Go) yardımcı programı için, -N şifreleme seçimini belirtmek üzere true, false, veya disable olabilecek bir dize değeri alır. (default parametresinin atlanmasıyla aynıdır):
-Nve-Csağlanmazsa, sqlcmd sunucu sertifikasını doğrulamadan sunucuyla kimlik doğrulaması müzakeresi yapar.-Nsağlanmışsa ancak-Csağlanmadıysa, sqlcmd sunucu sertifikasının doğrulanması gerekir. Şifreleme içinfalsedeğeri yine de oturum açma paketinin şifrelenmesini sağlayabilir.Hem
-Nhem de-Csağlanırsa, sqlcmd şifreleme anlaşması için değerlerini kullanır.sqlcmd'de (ODBC), sertifikada konak adını belirtmek için kullanın
-F. Örneğin:sqlcmd -S server01 -Q "SELECT TOP 100 * FROM WideWorldImporters.Sales.Orders" -A -Ns -F server01.adventure-works.comNote
Bu, sonuçları dikey biçim kullanarak yazdırmak için kullanılan
-F(Go) anahtarından farklıdır.
-P parola
Kullanıcı tarafından belirtilen bir parola. Parolalar büyük/küçük harfe duyarlıdır.
-U Seçenek kullanılırsa, -P seçenek kullanılmaz ve SQLCMDPASSWORD ortam değişkeni ayarlanmadıysa, sqlcmd kullanıcıdan parola ister. Null (boş) parola kullanılmasını önermeyiz, ancak parametre değeri ("") için bitişik çift tırnak işareti çifti kullanarak null parolayı belirtebilirsiniz.
Important
-P kullanımı güvensiz olarak kabul edilmelidir. Komut satırında parola vermekten kaçının. Alternatif olarak, SQLCMDPASSWORD ortam değişkenini kullanın veya -P seçeneğini atlayarak parolayı etkileşimli olarak girin.
güçlü bir parola kullanmanızı öneririz.
Parola istemi konsola yazdırılarak aşağıdaki şekilde gösterilir: Password:
Kullanıcı girişi gizlidir. Başka bir deyişle hiçbir şey görüntülenmez ve imleç konumunda kalır.
SQLCMDPASSWORD ortam değişkeni, geçerli oturum için varsayılan bir parola ayarlamanıza olanak tanır. Bu nedenle, parolaların toplu iş dosyalarına sabit kodlanması gerekmez. Aşağıdaki örnek önce komut isteminde SQLCMDPASSWORD değişkenini ayarlar ve ardından sqlcmd yardımcı programına erişir.
Komut isteminde aşağıdaki komutu yazın.
<password> geçerli bir parolayla değiştirin.
SET SQLCMDPASSWORD=<password>
sqlcmd
SET SQLCMDPASSWORD=<password>
sqlcmd
SET SQLCMDPASSWORD=<password>
sqlcmd
Kullanıcı adı ve parola bileşimi yanlışsa bir hata iletisi oluşturulur.
Note
Ortam OSQLPASSWORD değişkeni geriye dönük uyumluluk için tutulur.
SQLCMDPASSWORD ortam değişkeni, OSQLPASSWORD ortam değişkenine göre önceliklidir. Başka bir deyişle sqlcmd ve osql yan yana girişim olmadan kullanılabilir. Eski yazılımlar çalışmaya devam ediyor.
-P seçeneğiyle -E seçeneği kullanılırsa bir hata iletisi oluşturulur.
-P seçeneğinin ardından birden fazla bağımsız değişken gelirse, bir hata mesajı üretilir ve program sona erer.
Özel karakterler içeren bir parola bir hata iletisi oluşturabilir.
-Pkullanırken özel karakterlerden kurtulmanız veya bunun yerine SQLCMDPASSWORD ortam değişkenini kullanmanız gerekir.
Linux ve macOS'ta, seçeneği olmadan -G kullanıldığında -U, erişim belirteci içeren bir dosyayı belirten -P seçeneğini belirtir (v17.8+). Belirteç dosyası UTF-16LE (BOM yok) biçiminde olmalıdır.
Erişim belirteçleri çeşitli yöntemlerle elde edilebilir. Erişim belirtecinin, gönderildiği as-isadresine bayt bayt doğru olmasını sağlamanız gerekir. Aşağıda, erişim belirteci edinen örnek bir komut verilmiştir. Komutu Azure CLI ve Linux komutlarını kullanır ve uygun biçimde bir dosyaya kaydeder. Sisteminizin veya terminalinizin varsayılan kodlaması ASCII veya UTF-8 değilse, iconv seçeneklerini ayarlamanız gerekebilir. Sonuçta elde edilen dosyanın güvenliğini dikkatle aldığınızdan ve artık gerekli olmadığında dosyayı sildiğinizden emin olun.
az account get-access-token --resource https://database.windows.net --output tsv | cut -f 1 | tr -d '\n' | iconv -f ascii -t UTF-16LE > /tmp/tokenFile
-S [protokol:]sunucu[\instance_name][,bağlantı noktası]
Bağlanacak SQL Server örneğini belirtir.
sqlcmd betik değişkenini ayarlar SQLCMDSERVER.
Bu sunucu bilgisayardaki varsayılan SQL Server örneğine bağlanmak için server_name belirtin. Sunucu bilgisayardaki adlandırılmış bir SQL Server örneğine bağlanmak için [\instance_name] server_namebelirtin. Hiçbir sunucu bilgisayarı belirtilmezse, sqlcmd yerel bilgisayardaki varsayılan SQL Server örneğine bağlanır. Bu seçenek, ağdaki uzak bir bilgisayardan sqlcmd yürütürken gereklidir.
protokoltcp (TCP/IP), lpc (paylaşılan bellek) veya np (adlandırılmış kanallar) olabilir.
sqlcmd başlattığınızda [\instance_name] server_namebelirtmezseniz, SQL Server SQLCMDSERVER ortam değişkenini denetler ve bu değişkeni kullanır.
Note
Ortam OSQLSERVER değişkeni geriye dönük uyumluluk için tutulur.
SQLCMDSERVER ortam değişkeni, OSQLSERVER ortam değişkenine göre önceliklidir. Başka bir deyişle sqlcmd ve osql yan yana girişim olmadan kullanılabilir. Eski yazılımlar çalışmaya devam ediyor.
Linux ve macOS'ta ODBC sürücüsü gerektirir -S. Geçerli tek protokol değeridir tcp.
-U login_id
Oturum açma adı veya içeriğinde bulunan veritabanı kullanıcı adı. İçerilen veritabanı kullanıcıları için veritabanı adı seçeneğini (-d) sağlamanız gerekir.
Note
Ortam OSQLUSER değişkeni geriye dönük uyumluluk için tutulur.
SQLCMDUSER ortam değişkeni, OSQLUSER ortam değişkenine göre önceliklidir. Başka bir deyişle sqlcmd ve osql yan yana girişim olmadan kullanılabilir. Eski yazılımlar çalışmaya devam ediyor.
-U veya -P seçeneğini belirtmezseniz sqlcmd Windows Kimlik Doğrulama modunu kullanarak bağlanmaya çalışır. Kimlik doğrulaması, sqlcmd çalıştıran kullanıcının Windows hesabını temel alır.
-U seçeneği -E seçeneğiyle birlikte kullanılıyorsa (bu makalenin ilerleyen bölümlerinde açıklanmaktadır), bir hata iletisi oluşturulur.
-U seçeneğinin ardından birden fazla bağımsız değişken gelirse, bir hata mesajı üretilir ve program sona erer.
-z new_password
Parolayı değiştirin.
<oldpassword> eski parolayla, <newpassword> yeni parolayla değiştirin.
sqlcmd -U someuser -P <oldpassword> -z <newpassword>
sqlcmd -U someuser -P <oldpassword> -z <newpassword>
sqlcmd -U someuser -P <oldpassword> -z <newpassword>
-Z new_password
Parolayı değiştirin ve çıkın.
<oldpassword> eski parolayla, <newpassword> yeni parolayla değiştirin.
sqlcmd -U someuser -P <oldpassword> -Z <newpassword>
sqlcmd -U someuser -P <oldpassword> -Z <newpassword>
sqlcmd -U someuser -P <oldpassword> -Z <newpassword>
Giriş/çıkış seçenekleri
-f kod sayfası | i:kod sayfası[,o:kod sayfası] | o:kod sayfası[,i:kod sayfası]
Giriş ve çıkış kodu sayfalarını belirtir. Kod sayfası numarası, yüklü bir Windows kod sayfasını belirten sayısal bir değerdir.
Kod sayfası dönüştürme kuralları:
Kod sayfası belirtilmezse, giriş dosyası Unicode dosyası olmadığı sürece sqlcmd hem giriş hem de çıkış dosyaları için geçerli kod sayfasını kullanır ve bu durumda dönüştürme gerekmez.
sqlcmd hem büyük hem de küçük endian Unicode giriş dosyalarını otomatik olarak tanır.
-uSeçenek belirtilirse, çıkış her zaman küçük uçlu Unicode olur.Hiçbir çıkış dosyası belirtilmezse, çıkış kodu sayfası konsol kodu sayfasıdır. Bu yaklaşım, çıkışın konsolda doğru görüntülenmesini sağlar.
Birden çok giriş dosyasının aynı kod sayfasında olduğu varsayılır. Unicode ve Unicode olmayan giriş dosyaları karıştırılabilir.
chcpkod sayfasını doğrulamak için komut istemine cmd.exe girin.
Note
Linux'ta kod sayfası numarası, yüklü bir Linux kod sayfasını belirten sayısal bir değerdir (17.5.1.1'den itibaren kullanılabilir).
-F hostname_in_certificate
Sunucu sertifikası doğrulaması sırasında kullanılacak farklı, beklenen Ortak Ad (CN) veya Konu Diğer Adı (SAN) belirtir. Bu seçenek olmadan, sertifika doğrulaması sertifikadaki CN veya SAN'ın bağlandığınız sunucu adıyla eşleşmesini sağlar. Bu parametre, örneğin DNS diğer adları kullanılırken sunucu adı CN veya SAN ile eşleşmediğinde doldurulabilir.
-i input_file[,input_file2...]
Bir grup Transact-SQL deyimi veya saklı yordam içeren dosyayı tanımlar. Sırayla okunan ve işlenen birden çok dosya belirtilebilir. Dosya adları arasında boşluk kullanmayın.
sqlcmd, belirtilen tüm dosyaların mevcut olup olmadığını görmek için önce denetler. Bir veya daha fazla dosya yoksa sqlcmd çıkar.
-i ve -Q/-q seçenekleri birbirini dışlar.
Note
-i seçeneğini ve ardından bir veya daha fazla ek parametre kullanırsanız, parametre ile değer arasında boşluk bırakmanız gerekir. Bu, sqlcmd (Go) bilinen bir sorundur.
Yol örnekleri:
-i C:\<filename>
-i \\<Server>\<Share$>\<filename>
-i "C:\Some Folder\<file name>"
Boşluk içeren dosya yolları tırnak içine alınmalıdır.
Bu seçenek birden çok kez kullanılabilir:
sqlcmd -i <input_file1> -i <input_file2>
sqlcmd -i <input_file1> -i <input_file2>
sqlcmd -i <input_file1> -i <input_file2>
-o çıkış_dosyası
sqlcmdçıktısını alan dosyayı tanımlar.
-u belirtilirse, output_file Unicode biçiminde depolanır. Dosya adı geçerli değilse bir hata iletisi oluşturulur ve sqlcmd kapatılır.
sqlcmd, aynı dosyaya birden çok sqlcmd işleminin eşzamanlı olarak yazıldığını desteklemez. Dosya çıktısı bozuk veya yanlış.
-f seçeneği de dosya biçimleriyle ilgilidir. Dosya bulunmadığında oluşturulur. Önceki sqlcmd oturumundan aynı ada sahip bir dosyanın üzerine yazılır. Burada belirtilen dosya stdout dosyası değil. bir stdout dosyası belirtilirse, bu dosya kullanılmaz.
Yol örnekleri:
-o C:< filename>
-o \\<Server>\<Share$>\<filename>
-o "C:\Some Folder\<file name>"
Boşluk içeren dosya yolları tırnak içine alınmalıdır.
-r[0 | 1]
Hata mesajı çıkışını ekrana (stderr) yönlendirir. Parametre belirtmezseniz veya 0belirtirseniz, yalnızca önem düzeyi 11 veya daha yüksek olan hata iletileri yeniden yönlendirilir.
1belirtirseniz, PRINT dahil olmak üzere tüm hata iletisi çıkışı yeniden yönlendirilir.
-okullanıyorsanız bu seçeneğin hiçbir etkisi olmaz. varsayılan olarak, iletiler stdoutgönderilir.
Note
sqlcmd (Go) yardımcı programı için -r bir 0 veya 1 bağımsız değişkeni gerektirir.
-R
Şunlar için geçerlidir: Yalnızca ODBC sqlcmd.
sqlcmd istemcinin yerel ayarına göre SQL Server'dan alınan sayısal, para birimi, tarih ve saat sütunlarını yerelleştirmesine neden olur. Varsayılan olarak, bu sütunlar sunucunun bölgesel ayarları kullanılarak görüntülenir.
Note
Linux ve macOS'ta şu -R anda yalnızca (ABD İngilizcesi) biçimlendirmesi kullanılmaktadır en_US .
-u
input_filebiçiminden bağımsız olarak output_file Unicode biçiminde depolandığını belirtir.
Note
sqlcmd (Go) yardımcı programı için, oluşturulmuş Unicode çıkış dosyasına UTF-16 Little-Endian Bayt sırası işareti (BOM) yazılmıştır.
Sorgu yürütme seçenekleri
-e
Giriş betiklerini standart çıkış cihazına (stdout) yazar.
-I
Şunlar için geçerlidir: Yalnızca ODBC sqlcmd.
SET QUOTED_IDENTIFIER bağlantı seçeneğini ONolarak ayarlar. Varsayılan ayar OFF. Daha fazla bilgi için bkz. SET QUOTED_IDENTIFIER.
Note
sqlcmd (Go) yardımcı programında tanımlayıcı tırnak davranışını devre dışı bırakmak için betiklerinize SET QUOTED IDENTIFIER OFF olarak ekleyin.
-q "komut satırı sorgusu"
sqlcmd başlatıldığında sorgu yürütür, ancak sorgu tamamlandığında sqlcmd'dan çıkmaz. Birden çok noktalı virgülle ayrılmış sorgu yürütülebilir. Aşağıdaki örnekte gösterildiği gibi sorgunun çevresinde tırnak işaretleri kullanın.
Komut istemine şunu yazın:
sqlcmd -d AdventureWorks2022 -q "SELECT FirstName, LastName FROM Person.Person WHERE LastName LIKE 'Whi%';"
sqlcmd -d AdventureWorks2022 -q "SELECT TOP 5 FirstName FROM Person.Person;SELECT TOP 5 LastName FROM Person.Person;"
sqlcmd -d AdventureWorks2022 -q "SELECT FirstName, LastName FROM Person.Person WHERE LastName LIKE 'Whi%';"
sqlcmd -d AdventureWorks2022 -q "SELECT TOP 5 FirstName FROM Person.Person;SELECT TOP 5 LastName FROM Person.Person;"
sqlcmd -d AdventureWorks2022 -q "SELECT FirstName, LastName FROM Person.Person WHERE LastName LIKE 'Whi%';"
sqlcmd -d AdventureWorks2022 -q "SELECT TOP 5 FirstName FROM Person.Person;SELECT TOP 5 LastName FROM Person.Person;"
Important
Sorguda GO sonlandırıcısını kullanmayın.
-b bu seçenekle birlikte belirtilirse, sqlcmd bir hata oluştuğunda sonlanır.
-b bu makalenin başka bir yerinde açıklanmıştır.
-Q "komut satırı sorgusu"
sqlcmd başlatıldığında bir sorgu yürütür ve ardından sqlcmd hemen çıkar. Birden çok noktalı virgülle ayrılmış sorgu yürütülebilir.
Aşağıdaki örnekte gösterildiği gibi sorgunun çevresinde tırnak işaretleri kullanın.
Komut istemine şunu yazın:
sqlcmd -d AdventureWorks2022 -Q "SELECT FirstName, LastName FROM Person.Person WHERE LastName LIKE 'Whi%';"
sqlcmd -d AdventureWorks2022 -Q "SELECT TOP 5 FirstName FROM Person.Person;SELECT TOP 5 LastName FROM Person.Person;"
sqlcmd -d AdventureWorks2022 -Q "SELECT FirstName, LastName FROM Person.Person WHERE LastName LIKE 'Whi%';"
sqlcmd -d AdventureWorks2022 -Q "SELECT TOP 5 FirstName FROM Person.Person;SELECT TOP 5 LastName FROM Person.Person;"
sqlcmd -d AdventureWorks2022 -Q "SELECT FirstName, LastName FROM Person.Person WHERE LastName LIKE 'Whi%';"
sqlcmd -d AdventureWorks2022 -Q "SELECT TOP 5 FirstName FROM Person.Person;SELECT TOP 5 LastName FROM Person.Person;"
Important
Sorguda GO sonlandırıcısını kullanmayın.
-b bu seçenekle birlikte belirtilirse, sqlcmd bir hata oluştuğunda sonlanır.
-b bu makalenin başka bir yerinde açıklanmıştır.
-t query_timeout
Bir komutun (veya Transact-SQL deyiminin) zaman aşımına uğramasından önceki saniye sayısını belirtir. Bu seçenek, sqlcmd betik değişkenini SQLCMDSTATTIMEOUTbelirler.
query_timeout değeri belirtilmezse komut zaman aşımına neden olmaz. query_timeout1 ile 65534arasında bir sayı olmalıdır. Sağlanan değer sayısal değilse veya bu aralığa girmiyorsa sqlcmd bir hata iletisi oluşturur.
Note
Gerçek zaman aşımı değeri, belirtilen query_timeout değerinden birkaç saniye kadar değişebilir.
-v var = değer [ var = değer... ]
Şunlar için geçerlidir: yalnızca Windows. Linux ve macOS desteklenmez.
sqlcmd betiğinde kullanılabilecek bir sqlcmd betik değişkeni oluşturur.
Değer boşluk içeriyorsa, değeri tırnak içine alın. Birden çok <var>="<value>" değeri belirtebilirsiniz. Belirtilen değerlerden herhangi birinde hatalar varsa, sqlcmd bir hata iletisi oluşturur ve sonra çıkar.
sqlcmd -v MyVar1=something MyVar2="some thing"
sqlcmd -v MyVar1=something -v MyVar2="some thing"
sqlcmd -v MyVar1=something MyVar2="some thing"
sqlcmd -v MyVar1=something -v MyVar2="some thing"
sqlcmd -v MyVar1=something MyVar2="some thing"
sqlcmd -v MyVar1=something -v MyVar2="some thing"
-x
sqlcmd'in betik değişkenlerini yoksaymasına neden olur. Bu parametre, bir betik INSERTgibi normal değişkenlerle aynı biçime sahip dizeler içerebilen birçok $(<variable_name>) deyimi içerdiğinde yararlıdır.
Biçim seçenekleri
-h üst bilgileri
Sütun başlıkları arasında yazdırılacak satır sayısını belirtir. Varsayılan ayar, her sorgu sonucu kümesi için başlıkları bir kez yazdırmaktır. Bu seçenek, sqlcmd betik oluşturma değişkenini SQLCMDHEADERSayarlar. Üst bilgilerin yazdırılmaması gerektiğini belirtmek için -1 kullanın. Geçerli olmayan herhangi bir değer sqlcmd bir hata iletisi oluşturmasına ve ardından çıkışına neden olur.
-k [1 | 2]
Sekmeler ve yeni satır karakterleri gibi tüm denetim karakterlerini çıkıştan kaldırır. Bu parametre, veriler döndürülürken sütun biçimlendirmeyi korur.
-
-kdenetim karakterlerini kaldırır. -
-k1her denetim karakterini bir boşlukla değiştirir. -
-k2, ardışık denetim karakterlerini tek bir boşlukla değiştirir.
-s col_separator
Sütun ayırıcı karakterini belirtir. Varsayılan değer boş bir alandır. Bu seçenek, sqlcmd betik oluşturma değişkenini SQLCMDCOLSEPayarlar. İşletim sistemi için özel anlamı olan karakterler, örneğin ampersand (&) veya noktalı virgül (;) kullanırken, karakteri tırnak işareti (") içine alın. Sütun ayırıcı herhangi bir 8 bit karakter olabilir.
-w screen_width
Çıktının ekran genişliğini belirtir. Bu seçenek, sqlcmd betik oluşturma değişkenini SQLCMDCOLWIDTHayarlar. Sütun genişliği, 8'den büyük ve 65536küçük bir sayı olmalıdır. Belirtilen sütun genişliği bu aralığa düşmezse sqlcmd bir hata iletisi oluşturur. Varsayılan genişlik 80 karakterdir. Çıkış satırı belirtilen sütun genişliğini aştığında, sonraki satıra kaydırılır.
-W
Bu seçenek bir sütundan sondaki boşlukları kaldırır. Başka bir uygulamaya aktarılacak verileri hazırlarken bu seçeneği -s seçeneğiyle birlikte kullanın.
-y veya -Y seçenekleriyle kullanılamaz.
-y variable_length_type_display_width
sqlcmd betik değişkenini ayarlar SQLCMDMAXVARTYPEWIDTH. Varsayılan değer 256. Büyük değişken uzunluğundaki veri türleri için döndürülen karakter sayısını sınırlar:
- varchar(max)
- nvarchar(max)
- varbinary(max)
- xml
- kullanıcı tanımlı veri türlerini (UDT)
- text
- ntext
- image
UDF'ler uygulamaya bağlı olarak sabit uzunlukta olabilir. Sabit uzunluktaki UDT'nin uzunluğu display_widthdaha kısaysa döndürülen UDT değeri etkilenmez. Ancak, uzunluk display_width'den uzunsa çıkış kesilir.
Caution
Döndürülen verilerin boyutuna -y 0 bağlı olarak hem sunucuda hem de ağda önemli performans sorunlarına neden olabileceğinden bu seçeneği çok dikkatli kullanın.
-Y sabit_uzunluk_tipi_görünüm_genişliği
sqlcmd betik değişkenini ayarlar SQLCMDMAXFIXEDTYPEWIDTH. Varsayılan değer 0 (sınırsız). Aşağıdaki veri türleri için döndürülen karakter sayısını sınırlar:
- char(n), burada 1 <= n<= 8000
- nchar(n), burada 1 <= n<= 4000
- varchar(n), burada 1 <= n<= 8000
- nvarchar(n), burada 1 <= n<= 4000
- varbinary(n), burada 1 <= n<= 4000
- sql_variant
Hata raporlama seçenekleri
-b
sqlcmd çıkış yapıp bir hata oluştuğunda DOS ERRORLEVEL değeri döndürdüğünü belirtir. SQL Server hata iletisinin önem düzeyi 10'dan büyük olduğunda ERRORLEVEL değişkenine döndürülen değer 1; aksi takdirde, döndürülen değer 0.
-V seçeneği ayarlanırsa, -b seçeneği ile birlikte, önem düzeyi kullanılarak ayarlanan değerlerden düşükse, -V hata bildirmez. Komut istemi toplu iş dosyaları ERRORLEVEL değerini test edebilir ve hatayı uygun şekilde işleyebilir.
sqlcmd ciddiyet seviyesi 10 (bilgilendirme mesajları) için hataları bildirmez.
sqlcmd betiği yanlış bir yorum, sözdizimi hatası içeriyorsa veya bir betik değişkeni eksikse, ERRORLEVEL olarak döndürülen 1olur.
-m error_level
stdout'a gönderilecek hata iletilerini denetler. Önem düzeyi bu düzeyden büyük veya bu düzeye eşit olan iletiler gönderilir. Bu değer -1olarak ayarlandığında, bilgilendiren iletiler de dahil olmak üzere tüm iletiler gönderilir.
-m ile -1arasında boşluklara izin verilmez. Örneğin, -m-1 geçerli ve -m -1 geçerli değil.
Bu seçenek ayrıca sqlcmd betik oluşturma değişkeni SQLCMDERRORLEVELayarlar. Bu değişkenin varsayılan 0değeri vardır.
-V hata_şiddet_düzeyi
ERRORLEVEL değişkenini ayarlamak için kullanılan önem düzeyini denetler.
ERRORLEVELbu değer kümesinden büyük veya buna eşit önem düzeylerine sahip hata iletileri. 0'dan küçük değerler 0olarak bildirilir. Batch ve CMD dosyaları, ERRORLEVEL değişkeninin değerini test etmek için kullanılabilir.
Çeşitli seçenekler
-a packet_size
Farklı boyutta bir paket isteğinde bulunur. Bu seçenek, sqlcmd betik oluşturma değişkenini SQLCMDPACKETSIZEayarlar.
packet_size512 ile 32767arasında bir değer olmalıdır. Varsayılan değer 4096. Daha büyük bir paket boyutu, GO komutları arasında çok sayıda Transact-SQL deyimi içeren betiklerin yürütülmesi için performansı artırabilir. Daha büyük bir paket boyutu isteyebilirsiniz. Ancak, istek reddedilirse sqlcmd paket boyutu için varsayılan sunucuyu kullanır.
-c batch_terminator
Pake terminatörünü belirtir. Varsayılan olarak komutlar sonlandırılır ve tek başına bir satıra GO sözcüğü yazılarak SQL Server'a gönderilir. Toplu iş sonlandırıcısını sıfırladığınızda, işletim sistemi için özel anlamı olan karakterleri veya Transact-SQL ayrılmış anahtar sözcükleri, önünde bir ters eğik çizgi olsa bile, kullanmayın.
-L[c]
Şunlar için geçerlidir: yalnızca Windows. Linux ve macOS desteklenmez.
Yerel olarak yapılandırılmış sunucu bilgisayarlarını ve ağda yayınlayan sunucu bilgisayarlarının adlarını listeler. Bu parametre diğer parametrelerle birlikte kullanılamaz. Listelenebilen en fazla sunucu bilgisayarı sayısı 3000'dir. Sunucu listesi, arabellek kapasitesi nedeniyle kesilirse bir uyarı mesajı görüntülenir.
Note
Ağlarda yayın özelliği nedeniyle sqlcmd tüm sunuculardan zamanında yanıt alamayabilir. Bu nedenle, döndürülen sunucuların listesi bu seçeneğin her çağrısı için farklılık gösterebilir.
İsteğe bağlı parametre c belirtilirse, çıkış Servers: üst bilgi satırı olmadan görüntülenir ve her sunucu satırı başta boşluk olmadan listelenir. Bu sunum temiz çıktı olarak adlandırılır. Temiz çıkış, betik dillerinin işleme performansını artırır.
-p[1]
Her sonuç kümesi için performans istatistiklerini yazdırır. Aşağıdaki görüntü, performans istatistiklerinin biçimine bir örnektir:
Network packet size (bytes): n
x xact[s]:
Clock Time (ms.): total t1 avg t2 (t3 xacts per sec.)
Where:
-
x= SQL Server tarafından işlenen işlem sayısı. -
t1= Tüm işlemler için toplam süre. -
t2= Tek bir işlemin ortalama süresi. -
t3= Saniye başına ortalama işlem sayısı.
Tüm zamanlar milisaniye cinsindendir.
İsteğe bağlı parametre 1 belirtilirse, istatistiklerin çıkış biçimi, bir elektronik tabloya kolayca aktarılabilen veya bir betik tarafından işlenebilen, iki nokta ile ayrılmış bir formatta olur.
İsteğe bağlı parametre 1 dışında bir değerse bir hata oluşturulur ve sqlcmd sonlandırılır.
-X[1]
bir toplu iş dosyasından sqlcmd yürütürken sistem güvenliğini tehlikeye atabilecek komutları devre dışı bırakır. Devre dışı bırakılan komutlar hala tanınıyor; sqlcmd bir uyarı iletisi oluşturur ve devam eder. İsteğe bağlı parametre 1 belirtilirse, sqlcmd bir hata iletisi oluşturur ve sonra çıkar.
-X seçeneği kullanıldığında aşağıdaki komutlar devre dışı bırakılır:
ED-
!!komut
-X seçeneği belirtilirse, ortam değişkenlerinin sqlcmd'a geçirilmesini engeller. Ayrıca SQLCMDINI betik değişkeni kullanılarak belirtilen başlangıç betiğinin yürütülmesini engeller.
sqlcmd betik değişkenleri hakkında daha fazla bilgi için bkz. sqlcmd -betik değişkenleriyle kullanma.
-?
sqlcmd sürümünü ve sqlcmd seçeneklerinin söz dizimi özetini görüntüler.
Note
macOS'ta bunun yerine sqlcmd '-?' (tırnak işaretleri ile) çalıştırın.
Remarks
Seçeneklerin söz dizimi bölümünde gösterilen sırayla kullanılması gerekmez.
Note
-i seçeneğini ve ardından bir veya daha fazla ek parametre kullanırsanız, parametre ile değer arasında boşluk bırakmanız gerekir. Bu, sqlcmd (Go) bilinen bir sorundur.
Birden çok sonuç döndürülürse sqlcmd, toplu işlemdeki her sonuç kümesi arasında boş bir satır yazdırır. Ayrıca, <x> rows affected iletisi yürütülen deyime uygulanmadığında görünmez.
sqlcmd etkileşimli olarak kullanmak için, komut istemine bu makalenin önceki bölümlerinde açıklanan seçeneklerden herhangi biriyle veya daha fazlasıyla sqlcmd yazın. Daha fazla bilgi için bkz . sqlcmd kullanma.
Note
-l, -Q, -Z veya -i seçenekleri, yürütüldükten sonra sqlcmd çıkmasına neden olur.
Tüm bağımsız değişkenler ve genişletilmiş değişkenler dahil olmak üzere, komut ortamındaki sqlcmd komut satırının toplam uzunluğu (örneğin cmd.exe veya bash), temel işletim sistemi tarafından belirlenir.
sqlcmd ve bcp'de DSN desteği
belirtirseniz, bcp -S veya sqlcmd :Connect seçeneği (veya -D komutu) kullanırken sunucu adı yerine bir veri kaynağı adı (DSN) belirtebilirsiniz.
-D seçeneği, sqlcmd veya bcp'nin DSN'de belirtilen sunucuya bağlanmasına neden olur.
Sistem DSN'leri odbc.ini dosyasında, ODBC SysConfigDir dizininde (/etc/odbc.ini standart yüklemelerde) depolanır. Kullanıcı DSN'leri bir kullanıcının giriş dizininde .odbc.ini (~/.odbc.ini ) depolanır.
Windows sistemlerinde Sistem ve Kullanıcı DSN'leri kayıt defterinde depolanır ve aracılığıyla odbcad32.exeyönetilir.
bcp ve sqlcmd , dosya DSN'lerini desteklemez.
Sürücünün desteklediği girdilerin listesi için bkz. DSN ve Bağlantı Dizesi Anahtar Sözcükleri ve Öznitelikleri .
DSN'de yalnızca DRIVER giriş gereklidir, ancak uzak sunucuya bağlanmak için sqlcmd veya bcp öğesinde SERVER bir değere ihtiyaç duyar.
SERVER Öğe boşsa veya DSN'de yoksa, sqlcmd ve bcp yerel sistemdeki varsayılan örneğe bağlanmayı dener.
Windows sistemlerinde bcp kullandığınızda, SQL Server 2017 (14.x) ve önceki sürümler SQL Native Client 11 sürücüsünü (sqlncli11.dll) gerektirirken, SQL Server 2019 (15.x) ve sonraki sürümler için SQL Server sürücüsü (msodbcsql17.dll) için Microsoft ODBC Sürücüsü 17 gerekir.
Aynı seçenek hem DSN'de hem de sqlcmd veya bcp komut satırında belirtilirse, komut satırı seçeneği DSN'de kullanılan değeri geçersiz kılar. Örneğin, DSN'nin bir DATABASE girdisi varsa ve sqlcmd komut satırında -d içeriyorsa, geçirilen -d değeri kullanılır. DSN'de Trusted_Connection=yes belirtilmişse, Kerberos kimlik doğrulaması kullanılır; kullanıcı adı (-U) ve parola (-P) verilirse dikkate alınmaz.
isql çağıran mevcut betikler, aşağıdaki diğer ad tanımlanarak sqlcmd kullanacak şekilde değiştirilebilir: alias isql="sqlcmd -D".
sqlcmd en iyi uygulamaları
Güvenlik ve verimliliği en üst düzeye çıkarmak için aşağıdaki uygulamaları kullanın.
Tümleşik güvenliği kullanın.
Otomatik ortamlarda
-X[1]kullanın.Uygun dosya sistemi izinlerini kullanarak giriş ve çıkış dosyalarının güvenliğini sağlayın.
Performansı artırmak için, bir sqlcmd oturumunda olabildiğince çok işlem yapın, bir dizi oturum yerine.
Toplu iş veya sorgu yürütme için zaman aşımı değerlerini, toplu işlemi veya sorguyu yürütmek için beklediğinizden daha yüksek bir değere ayarlayın.
Doğruluğu en üst düzeye çıkarmak için aşağıdaki uygulamaları kullanın:
'yi önem derecesi 16 düzeyindeki iletileri günlüğe kaydetmek için kullanın. Önem derecesi 16 iletileri, kullanıcı tarafından düzeltilebilen genel hatalara işaret eder.İşlem çıktıktan sonra çıkış kodunu ve
DOS ERRORLEVELdeğişkenini denetleyin. sqlcmd 'ı normal şekilde0döndürür, aksi takdirdeERRORLEVEL'ü-Vtarafından yapılandırıldığı biçimde ayarlar. Başka bir deyişle,ERRORLEVELSQL Server'dan bildirilen hata numarasıyla aynı değer olması beklenemez. Hata numarası, @@ERROR sistem işlevine karşılık gelen SQL Server'a özgü bir değerdir.ERRORLEVEL, sqlcmd’in neden sonlandırıldığına işaret eden, sqlcmd’e özgü bir değerdir ve bu değerin nasıl belirleneceği, belirtilen-bkomut satırı bağımsız değişkeni tarafından etkilenir.
Çıkış kodu ve -V 16 denetimiyle birlikte DOS ERRORLEVEL kullanmak, üretim sürümünden önce özellikle kalite geçitleri olmak üzere otomatik ortamlardaki hataları yakalamaya yardımcı olabilir.
İlgili içerik
- sqlcmd yardımcı programının yüklü sürümünü denetleyin
- sqlcmd yardımcı programını indirme ve yükleme
- sqlcmd yardımcı programındaki komutlar
- Komut dosyası değişkenleriyle sqlcmd komutunu kullanma
- Hızlı Başlangıç: Docker ile SQL Server Linux kapsayıcı görüntülerini çalıştırma
- sqlcmd yardımcı programını başlatma
- sqlcmd ile bir betik dosyasından T-SQL yürütme
- sqlcmd kullanma
- sqlcmd ile SQL Server'a bağlanma
- Sorgu Düzenleyicisi ile SQLCMD Betiklerini Düzenleme
- CmdExec İş Adımı Oluşturma