❶ 誰能把這個UFT8編碼的「™」字元成功寫入Mysql,100分,不夠再加。用DELPHI或VC實現都可以。
delphi7可以的實現錄入,顯示就不行(目前沒找到正確方法),比較復雜點。
使用unidac控制項就可以實現。我是最終保存到Text類型的欄位中
思路:1,把UTF8文本保存到內存流,或是直接保存成文本(UTF8格式的)
2,用unidac的query控制項的sql語句是帶參數的。
3,用unidac的query控制項進行load內存流或是文本。
type
TForm1 = class(TForm)
mysqlnprvdr1: TMySQLUniProvider;
....
procere TForm1.btn2Click(Sender: TObject);
var
con3: TUniConnection;
unqry3: TUniQuery;
ms : TMemoryStream;
begin
con3:= TUniConnection.Create(nil);
con3.ProviderName := 'MySQL'
con3.SpecificOptions.Add('charset=utf8');
con3.SpecificOptions.Add('UseUnicode=true');
con3.Server := 餘.168.1.100'
con3.Port := 3306;
con3.Database := 'test'
con3.Username := 'root'
con3.Password := 'ro'
unqry3:= TUniQuery.Create(nil);
unqry3.Connection := con3;
unqry3.Close;
unqry3.SQL.Text := 'insert into api_a(content) '
+ 'values (:content )'
unqry3.ParamByName('content').ParamType := ptInput; //這句是必要的
unqry3.ParamByName('content').LoadFromFile(ƈ.txt',ftBlob);
unqry3.Execute;
unqry3.Close;
ms := TMemoryStream.Create;
ms.LoadFromFile(ƈ.txt');
unqry3.ParamByName('content').ParamType := ptInput; //這句是必要的
unqry3.ParamByName('content').LoadFromStream(ms,ftBlob);
unqry3.Execute;
unqry3.Close;
unqry3.Free;
con3.Free;
ms.Free;
end;
❷ Delphi+unidac+mysql,在模糊查詢時出現錯誤,不知怎麼改
從錯誤提示看,使用的是 MySql 資料庫,錯誤原因是由於 SQL 查詢語句的語法錯誤,錯誤位置在 [zddw_jbxx] 附近。
建議:
將[zddw_jbxx] 修改為 zddw_jbxx,即去掉 []。
2. 先將生成後 sql 語句,到 mysql 里先執行一下,如果正確再使用。
❸ SQL 存儲過程建立和使用方法
Sql Server的存儲過程是一個被命名的存儲在伺服器上的Transacation-Sql語句集合,是封裝重復性工作的一種方法,它支持用戶聲明的變數、條件執行和其他強大的編程功能。 存儲過程相對於其他的資料庫訪問方法有以下的優點: (1)重復使用。存儲過程可以重復使用,從而可以減少資料庫開發人員的工作量。 (2)提高性能。存儲過程在創建的時候就進行了編譯,將來使用的時候不用再重新編譯。一般的SQL語句每執行一次就需要編譯一次,所以使用存儲過程提高了效率。 (3)減少網路流量。存儲過程位於伺服器上,調用的時候只需要傳遞存儲過程的名稱以及參數就可以了,因此降低了網路傳輸的數據量。 (4)安全性。參數化的存儲過程可以防止SQL注入式的攻擊,而且可以將Grant、Deny以及Revoke許可權應用於存儲過程。 存儲過程一共分為了三類:用戶定義的存儲過程、擴展存儲過程以及系統存儲過程。 其中,用戶定義的存儲過程又分為Transaction-SQL和CLR兩種類型。 Transaction-SQL 存儲過程是指保存的Transaction-SQL語句集合,可以接受和返回用戶提供的參數。 CLR存儲過程是指對.Net Framework公共語言運行時(CLR)方法的引用,可以接受和返回用戶提供的參數。他們在.Net Framework程序集中是作為類的公共靜態方法實現的。(本文就不作介紹了) 創建存儲過程的語句如下:Code
CREATE { PROC | PROCEDURE } [schema_name.] procere_name [ ; number ]
[ { @parameter [ type_schema_name. ] data_type }
[ VARYING ] [ = default ] [ [ OUT [ PUT ]
] [ ,n ]
[ WITH <procere_option> [ ,n ]
[ FOR REPLICATION ]
AS { <sql_statement> [;][ n ] | <method_specifier> }
[;]
<procere_option> ::=
[ ENCRYPTION ]
[ RECOMPILE ]
[ EXECUTE_AS_Clause ]
<sql_statement> ::=
{ [ BEGIN ] statements [ END ] }
<method_specifier> ::=
EXTERNAL NAME assembly_name.class_name.method_name [schema_name]: 代表的是存儲過程所屬的架構的名稱 例如: Create Schema yangyang8848
Go
Create Proc yangyang8848.AllGoods
As Select * From Master_Goods
Go 執行:Exec AllGoods 發生錯誤。 執行:Exec yangyang8848.AllGoods 正確執行。 [;Number]: 用於對同名過程進行分組的可選整數。使用一個 DROP PROCEDURE 語句可將這些分組過程一起刪除。 例如: Create Proc S1 ;1
AS
Select * From Master_Goods
Go
Create Proc S1 ;2
As
Select * From Master_Location
Go 創建完畢了兩個存儲過程。它們在同一個組S1里,如果執行Exec S1 則存儲過程默認執行 Exec S1 ;1 。如果我們想得到所有據點信息則需要執行Exec S1 ;2。當我們要刪除存儲過程的時候,只能執行Drop Exec S1 則該組內所有的存儲過程被刪除。 [@ parameter]: 存儲過程中的參數,除非將參數定義的時候有默認值或者將參數設置為等於另一個參數,否則用戶必須在調用存儲過程的時候為參數賦值。 存儲過程最多有2100個參數。 例如: Create Proc yangyang8848.OneGoods
@GoodsCode varchar(10)
As
Select * From Master_Goods Where GoodsCode = @GoodsCode
Go 調用的代碼: Declare @Code varchar(10)
Set @Code = '0004'
Exec yangyang8848.OneGoods @Code 在參數的後邊加入Output 表明該參數為輸出參數。 Create Proc yangyang8848.OneGoods
@GoodsCode2 varchar(10) output,@GoodsCode varchar(10) = '0011'
As
Select * From Master_Goods Where GoodsCode = @GoodsCode
Set @GoodsCode2 = '0005'
Go 調用方法:
Declare @VV2 varchar(10)
Exec yangyang8848.OneGoods @Code out 注意:如果存儲過程的兩個參數一個有默認值一個沒有,那麼我們要把有默認值得放在後邊,不然會出問題哦~~ 細心的朋友,可能看到上邊的語句有一些不同,比如,存儲過程用的是output,而調用語句用的是out。我要告訴您,兩者是一樣的。 [RECOMPILE]:指示資料庫引擎 不緩存該過程的計劃,該過程在運行時編譯。如果指定了 FOR REPLICATION,則不能使用此選項。對於 CLR 存儲過程,不能指定 RECOMPILE。 這個說一個非常好用的函數 OBJECT_ID :返回架構范圍內對象的資料庫對象標識號。 例如:我們創建存儲過程時,可以如下寫代碼 If Object_ID('yangyang8848.OneGoods') Is Not Null
Drop Proc yangyang8848.OneGoods
Go Create Proc yangyang8848.OneGoods
@GoodsCode2 varchar(10) out,@GoodsCode varchar(10) = '0011'
As
Select * From Master_Goods Where GoodsCode = @GoodsCode
Set @GoodsCode2 = '0005'
Go 針對於上邊的這個存儲過程,我們調用以下SQL查詢 Select definition From sys.sql_moles
Where object_id = Object_ID('yangyang8848.OneGoods'); 我們是可以查到結果的。 可是如果我們對該存儲過程加入[ ENCRYPTION ] 那麼你將無法看到任何結果 If Object_ID('yangyang8848.OneGoods') Is Not Null
Drop Proc yangyang8848.OneGoods
Go Create Proc yangyang8848.OneGoods
@GoodsCode2 varchar(10) out,@GoodsCode varchar(10) = '0011' With Encryption
As
Select * From Master_Goods Where GoodsCode = @GoodsCode
Set @GoodsCode2 = '0005'
Go</SPAN> 然後我們查詢 sys.sql_moles 目錄視圖,將返回給你Null。</p> 然後我們執行以下SQL: Exec sp_helptext 'yangyang8848.OneGoods' 你將得到以下結果:The text for object 'yangyang8848.OneGoods' is encrypted. 說到這里你應該明白了,參數[ ENCRYPTION ]:是一種加密的功能, 將 CREATE PROCEDURE 語句的原始文本轉換為模糊格式。模糊代碼的輸出在 SQL Server 2005 的任何目錄視圖中都不能直接顯示。對系統表或資料庫文件沒有訪問許可權的用戶不能檢索模糊文本。但是,可通過 DAC 埠訪問系統表的特權用戶或直接訪問資料庫文件的特權用戶可使用此文本。此外,能夠向伺服器進程附加調試器的用戶可在運行時從內存中檢索已解密的過程。 前兩天寫了一篇關於游標的介紹文章 ,下邊寫一個例子,將游標與存儲過程一起使用上: If Object_ID('dbo.GetMasterGoods') Is Not Null
Drop Proc dbo.GetMasterGoods
Go Create Proc GetMasterGoods
@MyCursor Cursor Varying Output
With Encryption
As
Set @MyCursor = Cursor
For
Select GoodsCode,GoodsName From Master_Goods
Open @MyCursor
Go --下邊建立另外一個存儲過程,用於遍歷游標輸出結果 Create Proc GetAllGoodsIDAndName
As Declare @GoodsCode varchar(18)
Declare @GoodsName nvarchar(20)
Declare @MasterGoodsCursor Cursor
Exec GetMasterGoods @MasterGoodsCursor out
Fetch Next From @MasterGoodsCursor
InTo @GoodsCode,@GoodsName
While(@@Fetch_Status = 0)
Begin
Begin
Print @GoodsCode + ':' + @GoodsName
End
Fetch Next From @MasterGoodsCursor
InTo @GoodsCode,@GoodsName
End
Close @MasterGoodsCursor
Deallocate @MasterGoodsCursor
Go 最後執行Exec GetAllGoodsIDAndName結果為以下內容 0003:品0003
0004:品0004
0005:123123
0006:品0006
0007:品0007
0008:品0008
0009:品0009
0010:品0010
0011:品0011
0012:品0012
0013:品0013
0014:品0014
❹ 用UniDAC連接MySQL資料庫,為什麼連不上
UniDAC?我也是一直用的這個,你是不是在設計的時候直接用Connection連接資料庫了?最後編譯的時候要斷開,不斷開的話,它會直接以你在設計期間的設計去連接那個資料庫。
可以試試ZeosLib .
ZeosLib 是一組可以在 Delphi、FreePascal、Kylix 和 C++ Builder 中使用的資料庫訪問組件,支持包括 MySQL, PostgreSQL, Interbase, Firebird, MS SQL, Sybase, Oracle 和 SQLite 在內的資料庫系統。著名的 HeidiSQL 資料庫管理工具就是使用該組件來連接MySQL資料庫。目前此版本已經支持delphi & C++Builder XE.
❺ unidac 怎麼對數據的插入和更新
要想有返回值整個存儲過程 out一個參數。
不用存儲過程try except 一下,無異常視為成功。
ExecSQL返回的是Integer類型,結果就是更新的記錄數
i:=form1.UniQuery4.ExecSQL;
showmessage(inttostr(i));
❻ Delphi unidac連接oracle問題,一個很奇怪的問題
這應該和oracle伺服器的設置或者版本有關,我的程序在大多數現場運行正常,但在某些現場會出現不識別SID的問題,資料庫是客戶創建的,而不是我們自己設計的,版本號也各不相同。遇到這個問題,我就不使用uniconnection了,改為ado,安裝oracle客戶端配置服務名再訪問。
❼ delphi unidac 怎麼用
unidac 是一套功能強大的支持多種資料庫的數據訪問組件包,可以對當前流行的資料庫進行統一的訪問,包括Oracle,Microsoft SQL Server,MySQL,InterBase,Firebird,PostgreSQL,SQLite,DB2,Microsoft Access等等。
在 delphi 中使用 unidac 搭建資料庫方面的應用,與使用 AdoConection、AdoQuery 等 delphi 內置組件編寫應用的過程類似。
由於 unidac 是第三方組件,首先需要安裝。
其使用的示例(連接到 mysql)如下:
1. 新建一個應用程序,拖動TUniConnection、TMySQLUniProvider、TUniQuery、TUniDataSource、TDBGrid 到窗體上:
2. 設置 TUniConnection ,填入資料庫連接參數。
3. 使用 UniQuery ,編寫 SQL 獲取資料庫的數據。
❽ 如何用dac連接sql server
即使在 SQL Server 不響應標准連接請求時,管理員也可以使用這種連接訪問 SQL Server,以便執行診斷查詢並解決問題。命令行界面 (sqlcmd) 通過使用特殊的管理員開關 (-A),提供並支持這種專用管理員連接 (DAC)。
1 本機DAC登錄
命令行方式下執行 sqlcmd -A -S sql伺服器名
2 遠程DAC登錄
1)打開遠程DAC選項
EXEC sp_configure 'remote admin connections', 1;
RECONFIGURE;
2)登錄到遠程伺服器
sqlcmd -A -S 192.168.0.1 -U sa -P 123456
3 登錄後, 可以通過查詢動態管理視圖來診斷問題
❾ Delphi中UniDAC鏈接Mysql問題
首先,確定UniConnection連接是OK的了;然後,Uniquery的Connection屬性指定到Uniconnection了嗎?
❿ sql server 2005怎樣使用DAC管理員連接,連接本地伺服器的就可以
你是用SSMS工具嗎,打開工具出現登錄界面時不要直接使用DAC方式進行連接,而是選擇取消。然後單擊「新建查詢」,出現登錄界面時在伺服器名稱前加admin:(注意不是登錄名前)來登錄即可。
使用sqlcmd的話,還要在-S選項後寫上你的sql server的名字,一般是你的計算機名。