UPDATETEXT的举例用法

Update XXX set YYY=YYY+'ZZZZZ'
这样写不对,怎么样才能在更新时,保存原来的Ntext型的数据,并追加新的数据?

UPDATETEXT
更新现有 text、ntext 或 image 字段。使用 UPDATETEXT 在适当的位置更改 text、ntext 或 image 列的一部分。使用 WRITETEXT 来更新和替换整个 text、ntext 或 image 字段。

语法
UPDATETEXT { table_name.dest_column_name dest_text_ptr }
    { NULL | insert_offset }
    { NULL | delete_length }
    [ WITH LOG ]
    [ inserted_data
        | { table_name.src_column_name src_text_ptr } ]

create table #
(
  txt Ntext
)
insert # select 'ABCDEFGHIJK'

--测试
declare @t binary(16)
select @t=textptr(txt) from #
updatetext #.txt @t null null '新数据'

select * from #

--删除测试环境
drop table #

--结果
/*

txt                   
--------------------
ABCDEFGHIJK新数据
*/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Windows窗体应用程序中,如果多个线程需要同时访问同一个控件(如Label、TextBox等),就需要使用线程安全的方法来访问控件,以避免出现访问冲突和其他线程安全问题。 以下是一个示例,展示如何以线程安全的方式访问跨线程控件: ```csharp public partial class Form1 : Form { private delegate void UpdateTextDelegate(string text); public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { // 创建一个新线程 Thread thread = new Thread(new ThreadStart(ThreadMethod)); thread.Start(); } private void ThreadMethod() { // 线程执行的代码 // ... // 调用UpdateText方法更新跨线程控件 string text = "Hello from thread " + Thread.CurrentThread.ManagedThreadId; UpdateText(text); } private void UpdateText(string text) { // 如果当前线程不是UI线程,则通过Invoke方法调用UpdateTextDelegate委托 if (this.InvokeRequired) { UpdateTextDelegate updateText = new UpdateTextDelegate(UpdateText); this.Invoke(updateText, new object[] { text }); } else { // 否则直接更新控件 label1.Text = text; } } } ``` 在上面的示例中,我们创建了一个新线程,并在该线程中调用了ThreadMethod方法。在ThreadMethod方法中,我们调用了UpdateText方法来更新跨线程控件。在UpdateText方法中,我们首先检查当前线程是否是UI线程,如果不是,则通过Invoke方法调用UpdateTextDelegate委托来在UI线程中更新控件;如果是,则直接更新控件。 通过这种方式,我们可以实现多线程处理,并且以线程安全的方式访问跨线程控件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值