lingxi22 2011-11-29 14:37
浏览 453
已采纳

使用jdbc连接sqlite3时,blob数据该怎么存入取出?

[code="java"]
Class.forName("org.sqlite.JDBC");
conn = DriverManager.getConnection("jdbc:sqlite://e:/hello.db");
Statement stmt = conn.createStatement();
[/code]

  • 写回答

1条回答 默认 最新

  • jiangguangxian 2011-11-30 08:27
    关注

    我只能给你两个c#的代码,给你一点参考:

    [code="java"]
    public static Dictionary GetBlob(string dirPath)
    {
    Dictionary dic = new Dictionary();

            List<string> lst = new List<string>();
            string strSQL = "select * from Resource";
            SQLiteCommand cmd = Connection.CreateCommand();
            cmd.CommandText = strSQL;
    
            try
            {
                if (Connection.State != ConnectionState.Open)
                    Connection.Open();
                SQLiteDataReader dataReader = cmd.ExecuteReader();
    
                while (dataReader.Read())
                {
                    string itemId = dataReader["ID"].ToString();
                    int nDataLen = (int)dataReader.GetBytes(1, 0, null, 0, 0);
                    byte[] pbyData = new byte[nDataLen];
                    dataReader.GetBytes(1, 0, pbyData, 0, nDataLen);
                    string fileName = string.Format(Path.Combine(dirPath, itemId + ".zip"));
                    dic[itemId] = fileName;
                    FileStream fs = new FileStream(fileName, FileMode.Create, FileAccess.Write);
                    fs.Write(pbyData, 0, nDataLen);
                    fs.Close();
                }
                dataReader.Close();
            }
            catch (Exception ex)
            {
                throw ex;
            }
            finally
            {
                cmd.Dispose();
                Connection.Close();
            }
            return dic;
        }
    
        public static int InsertBlob(string cmdText, byte[] data)
        {
            SQLiteCommand command = new SQLiteCommand();
            int nRowCount = 0;
            try
            {
                if (Connection.State != ConnectionState.Open)
                    Connection.Open();
                SQLiteParameter para = new SQLiteParameter("data", DbType.Binary);
                para.Value = data;
                command.Parameters.Add(para);
                command.Connection = Connection;
                command.CommandText = cmdText;
                command.CommandType = CommandType.Text;
                command.CommandTimeout = 30;
                nRowCount = command.ExecuteNonQuery();
            }
            catch (Exception ex)
            {
            }
            finally
            {
                command.Dispose();
                Connection.Close();
            }
            return nRowCount;
    
        }
    

    [/code]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 有赏,i卡绘世画不出
  • ¥15 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入
  • ¥40 使用MATLAB解答线性代数问题
  • ¥15 COCOS的问题COCOS的问题
  • ¥15 FPGA-SRIO初始化失败
  • ¥15 MapReduce实现倒排索引失败
  • ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
  • ¥15 找一位技术过硬的游戏pj程序员
  • ¥15 matlab生成电测深三层曲线模型代码