我想在 bash 脚本中将二进制数据(png、jpg、gif 等)插入到 sqlite3 数据库中。
我使用独立的二进制文件sqlite3。如何编写 SQL 语句?
谢谢你的帮助。
			
			14546 次
		
2 回答
            10        
        
		
正如我在@sixfeetsix 答案的评论中提到的,插入数据只是问题的一半。一旦它进入,您需要将其取出。我们可以为此使用 xxd。
#A nice hubble image to work with.
echo 'http://asd.gsfc.nasa.gov/archive/hubble/Hubble_20th.jpg' > imageurl.txt
image=imageurl.txt
curl $image > image.jpg
#Insert the image, using hexdump to read the data into SQLite's BLOB literal syntax.
echo "create table images (image blob);" | sqlite3 images.db
echo "insert into images (image) values(x'$(hexdump -ve '1/1 "%0.2X"' image.jpg)');" | sqlite3 images.db 2>&1
#Select just the one image, then use xxd to convert from hex back to binary.
echo "select quote(image) from images limit 1 offset 0;" | sqlite3 images.db  | tr -d "X'" | xxd -r -p > newimage.jpg
eog newimage.jpg 
于 2012-04-28T15:02:25.240   回答
    
    
            5        
        
		
这是一种方法。该文件被编辑成sqlite的二进制文字格式后test.jpg插入foo到数据库的表中:foodbhexdump
[someone@somewhere tmp]$ sqlite3 foodb "create table foo (bar blob);"
[someone@somewhere tmp]$ echo "insert into foo values (X'`hexdump -ve '1/1 "%.2x"' test.jpg`');" | sqlite3 foodb
编辑
在这里,我们看到数据以“全保真”方式存储,因为 .jpg 文件可以恢复:
[somneone@somewhere tmp]$ sqlite3 foodb "select quote(bar) from foo;" | perl -ne 's/([0-9a-f]{2})/print chr hex $1/gie' > bla.jpg 
[somneone@somewhere tmp]$ ll *.jpg
-rw-rw-r-- 1 someone someone 618441 Apr 28 16:59 bla.jpg
-rw-rw-r-- 1 someone someone 618441 Apr 28 16:37 test.jpg
[someone@somewhere tmp]$ md5sum *.jpg 
3237a2b76050f2780c592455b3414813  bla.jpg
3237a2b76050f2780c592455b3414813  test.jpg
此外,这种方法节省空间,因为它使用 sqlite 的 BLOB 类型存储 .jpg。它不会使用例如 base64 编码对图像进行字符串化。
[someone@somewhere tmp]$ ll foodb 
-rw-r--r-- 1 someone someone 622592 Apr 28 16:37 foodb
于 2012-04-28T14:37:01.520   回答