17

对 postgresql 数据库的非常简单的更新,但它不起作用。sql select 语句很好,并返回正确的值。

当我进行更新时,它会引发错误:

 {"ERROR [0A000] ERROR: cross-database references are not implemented: "openerp.public.product_template"; Error while executing the query"}.

我正在使用 vb.net 和 postgresql 9.2。

我想要做的就是更改名称字段以匹配描述中的内容。

log:
LOG 0   duration: 34.000 ms  statement: SELECT * FROM product_template where import_date = '08/22/2013'
LOG 0   duration: 11.000 ms  statement: select n.nspname, c.relname, a.attname, a.atttypid, t.typname, a.attnum, a.attlen, a.atttypmod, a.attnotnull, c.relhasrules, c.relkind, c.oid, d.adsrc from (((pg_catalog.pg_class c inner join pg_catalog.pg_namespace n on n.oid = c.relnamespace and c.oid = 20496) inner join pg_catalog.pg_attribute a on (not a.attisdropped) and a.attnum > 0 and a.attrelid = c.oid) inner join pg_catalog.pg_type t on t.oid = a.atttypid) left outer join pg_attrdef d on a.atthasdef and d.adrelid = a.attrelid and d.adnum = a.attnum order by n.nspname, c.relname, attnum
LOG 0   duration: 12.000 ms  parse _PLAN000000001D2CFB60: SELECT * FROM product_template where import_date = '08/22/2013'
LOG 0   duration: 11.000 ms  statement: select ta.attname, ia.attnum, ic.relname, n.nspname, tc.relname from pg_catalog.pg_attribute ta, pg_catalog.pg_attribute ia, pg_catalog.pg_class tc, pg_catalog.pg_index i, pg_catalog.pg_namespace n, pg_catalog.pg_class ic where tc.oid = 20496 AND tc.oid = i.indrelid AND n.oid = tc.relnamespace AND i.indisprimary = 't' AND ia.attrelid = i.indexrelid AND ta.attrelid = i.indrelid AND ta.attnum = i.indkey[ia.attnum-1] AND (NOT ta.attisdropped) AND (NOT ia.attisdropped) AND ic.oid = i.indexrelid order by ia.attnum
LOG 0   duration: 0.000 ms  statement: select current_schema()
LOG 0   duration: 1.000 ms  statement: select c.relhasrules, c.relkind, c.relhasoids from pg_catalog.pg_namespace u, pg_catalog.pg_class c where u.oid = c.relnamespace and c.relname = 'product_template' and u.nspname = 'public'
LOG 0   duration: 1.000 ms  statement: select c.relhasrules, c.relkind, c.relhasoids from pg_catalog.pg_namespace u, pg_catalog.pg_class c where u.oid = c.relnamespace and c.relname = 'product_template' and u.nspname = 'public'
ERROR   0A000   cross-database references are not implemented: "openerp.public.product_template"

编码:

Private Sub btnChgNameToDescr_Click(sender As Object, e As EventArgs) Handles btnChgNameToDescr.Click

    Dim objConn As New System.Data.Odbc.OdbcConnection
    Dim objCmd As New System.Data.Odbc.OdbcCommand
    Dim dtAdapter As New System.Data.Odbc.OdbcDataAdapter
    Dim ds As New DataSet

    Me.Cursor = System.Windows.Forms.Cursors.WaitCursor

    Dim strConnString As String
    Dim strSQL As String
    Dim iRecCount As Integer

    Me.Cursor = System.Windows.Forms.Cursors.WaitCursor

    If objConn.State = ConnectionState.Open Then
        'do nothing
    Else
        strConnString = "Dsn=PostgreSQL35W;database=OpenERP;server=localhost;port=5432;uid=openpg;pwd=openpgpwd"
        objConn.ConnectionString = strConnString
        objConn.Open()
    End If


    If Me.txtImportDate.Text = "" Then
        MsgBox("Import Date field cannot be blank.")
        Exit Sub
    End If

    Dim str_import_date As String = Me.txtImportDate.Text


    strSQL = "SELECT * FROM product_template where import_date = " & "'" & str_import_date & "'"

    dtAdapter.SelectCommand = objCmd

    With objCmd
        .Connection = objConn
        .CommandText = strSQL
        .CommandType = CommandType.Text
        .ExecuteNonQuery()

        dtAdapter.Fill(ds, "product_template")

        iRecCount = ds.Tables("product_template").Rows.Count

    End With

    If iRecCount = 0 Then
        MsgBox("No records found.")
        Me.Cursor = System.Windows.Forms.Cursors.Default
        Exit Sub
    End If


    Dim cb As New Odbc.OdbcCommandBuilder(dtAdapter)


    'change the name field to item_description
    With ds
        For i As Integer = 0 To .Tables("product_template").Rows.Count - 1

            'this works, returns a string
            Dim str_default_code As String = (.Tables(0).Rows(i).Item("name").ToString)
            'this works
            Dim str_item_description As String = (.Tables(0).Rows(i).Item("description").ToString)

            .Tables("product_template").Rows(i).Item("name") = str_item_description
            'setting the variable doesn't work either - Dim str_item_description As String = "BH LITE BRT"

            'this throws the error
            dtAdapter.Update(ds, "product_template")

        Next
    End With

    Me.Cursor = System.Windows.Forms.Cursors.Default
End Sub
4

5 回答 5

6

如果您在 DBeaver 中遇到此错误,将目标数据库设置为活动可能会解决它:

在此处输入图像描述

这与多数据库支持有关

于 2020-01-20T16:15:59.800 回答
4

在您的 postgresql 日志中查找错误以查看实际发送到数据库的内容。我不知道如何修复您的代码,因为我不太了解该平台。此外,您需要转向参数化查询,因为您当前的方法将受到 sql 注入问题的影响。

但是,您的错误意味着您有一个额外的命名空间。正常的命名空间是schema.table.columnschema.table取决于上下文。如果您尝试指定一个表,schema.table.column它会将其读取为database.schema.table并抛出此错误。同样,如果您有一个额外的点,您可能会意外指定database.schema.table.column(这也会引发错误)。

这就是为什么字符串化 SQL 确实是一个坏主意的部分原因,但并没有真正触及问题的表面。

于 2013-11-11T03:29:41.497 回答
1

我在使用 DataGrip(版本 2020.3)时遇到了同样的问题。

就我而言,这是因为我更改了连接设置,但一直使用相同的控制台窗口。

我找到了两种解决方法:

  1. 更改控制台的会话(在控制台右键-->切换会话-->新建会话)
  2. 打开一个新的控制台窗口
于 2021-03-08T08:26:34.200 回答
0

在使用前缀模式名称进行截断表时,注意到 Redshift 存在相同的错误。

截断 schema_name.table_name;

虽然从 S3 加载复制是在没有架构名称的情况下完成的。总之,截断表应具有与复制命令中使用的模式相同的模式,以避免在 Redshift 中出现此错误。

https://docs.aws.amazon.com/redshift/latest/dg/r_TRUNCATE.html

于 2021-08-25T03:49:33.600 回答
0

今天正在做某事并得到了这个 - 最后是因为我的数据库名称中有大写字母,而命令没有 - prodCRT.public.tablename vs. prodcrt.public.tablename

一旦我将模式重命名为小写,我以前工作的所有命令都会再次工作。

注意:原始数据库仅称为“prod”-所以当我将其称为 prodCRT 时,事情就发生了

于 2020-10-29T13:49:36.637 回答