From 7208d3e9ebc05591059f8244dee88bd91a73dee3 Mon Sep 17 00:00:00 2001 From: Ekaitz Zarraga Date: Mon, 19 Aug 2024 00:47:34 +0200 Subject: PreparedStatement: work with strings --- src/duckdb/Database.zig | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) (limited to 'src/duckdb/Database.zig') diff --git a/src/duckdb/Database.zig b/src/duckdb/Database.zig index ffdd052..8a34696 100644 --- a/src/duckdb/Database.zig +++ b/src/duckdb/Database.zig @@ -175,3 +175,31 @@ test "Prepared queries" { r = try result.next(); try std.testing.expect(r.primer == dos); } + +test "Prepared queries with strings" { + var database = try Self.init(":memory:"); + defer database.deinit(); + var connection = try database.connect(); + defer connection.deinit(); + + try connection.run("CREATE TABLE ints (i STRING NOT NULL );"); + var prepared = try connection.prepareStatement("INSERT INTO ints VALUES (?), (?);"); + defer prepared.deinit(); + + const uno = "1"; + const dos = "2"; + try prepared.bindAll(.{uno, dos}); + var res = try prepared.exec(void); + res.deinit(); + + const s: type = struct { + primer: []const u8, + }; + var result = try connection.query("SELECT * FROM ints;", s); + defer result.deinit(); + + var w = try result.next(); + try std.testing.expect(std.mem.eql(u8, w.primer, "1")); + w = try result.next(); + try std.testing.expect(std.mem.eql(u8, w.primer, "2")); +} -- cgit v1.2.3