C# SQLite3 Select 如果为空
C# SQLite3 Select if null
如果数据库中不存在要查找的内容,我希望代码执行某些操作。这就是我目前正在使用的:
const string cs = @"Data Source= ..\..\..\database.sqlite3";
await using var con = new SQLiteConnection(cs);
con.Open();
await using var cmd = new SQLiteCommand(con);
member ??= ctx.Member;
cmd.CommandText = @"SELECT iq FROM users WHERE id = $user_id";
cmd.Parameters.AddWithValue("$user_id", member.Id);
var r = cmd.ExecuteReader();
while (r.Read())
{
if (r["iq"] == null)
{
var random = new Random();
var iq = random.Next(1, 200);
await cmd.DisposeAsync();
cmd.CommandText = "INSERT INTO users(id, iq) VALUES($member_id, $id)";
cmd.Parameters.AddWithValue("$iq", iq);
cmd.Parameters.AddWithValue("$member_id", member.Id);
cmd.ExecuteNonQuery();
var embed = new DiscordEmbedBuilder
{
Title = $"IQ of {member.Username} is {iq} :brain:",
Color = DiscordColor.Cyan
};
await ctx.Channel.SendMessageAsync(embed);
}
else
{
var iqFinal = r["iq"];
var embed = new DiscordEmbedBuilder
{
Title = $"IQ of {member.Username} is {iqFinal} :brain:",
Color = DiscordColor.Cyan
};
await ctx.Channel.SendMessageAsync(embed);
}
}
我真的不知道如何做到这一点,我已经尝试了 try catch
块,但它们似乎也没有用。我该怎么做?
我假定 id
是 table 的主键,因此您预计语句中不会超过 1 行:
SELECT iq FROM users WHERE id = $user_id
此语句的问题在于,如果 table 中不存在 $user_id
,它可能不会 return 任何行,因此在这种情况下 r.Read()
将 return false
和 while
循环中的代码永远不会被执行。
一种方法是使用聚合:
SELECT MAX(iq) AS iq FROM users WHERE id = $user_id
总是 return 一行:如果 $user_id
中不存在带有 id = $user_id
的 iq
行或 null
43=].
您还应该将 while
循环更改为:
if (r.Read()) {
.....................
}
或更好:
r.Read();
因为聚合查询保证 return 恰好 1 行。
如果数据库中不存在要查找的内容,我希望代码执行某些操作。这就是我目前正在使用的:
const string cs = @"Data Source= ..\..\..\database.sqlite3";
await using var con = new SQLiteConnection(cs);
con.Open();
await using var cmd = new SQLiteCommand(con);
member ??= ctx.Member;
cmd.CommandText = @"SELECT iq FROM users WHERE id = $user_id";
cmd.Parameters.AddWithValue("$user_id", member.Id);
var r = cmd.ExecuteReader();
while (r.Read())
{
if (r["iq"] == null)
{
var random = new Random();
var iq = random.Next(1, 200);
await cmd.DisposeAsync();
cmd.CommandText = "INSERT INTO users(id, iq) VALUES($member_id, $id)";
cmd.Parameters.AddWithValue("$iq", iq);
cmd.Parameters.AddWithValue("$member_id", member.Id);
cmd.ExecuteNonQuery();
var embed = new DiscordEmbedBuilder
{
Title = $"IQ of {member.Username} is {iq} :brain:",
Color = DiscordColor.Cyan
};
await ctx.Channel.SendMessageAsync(embed);
}
else
{
var iqFinal = r["iq"];
var embed = new DiscordEmbedBuilder
{
Title = $"IQ of {member.Username} is {iqFinal} :brain:",
Color = DiscordColor.Cyan
};
await ctx.Channel.SendMessageAsync(embed);
}
}
我真的不知道如何做到这一点,我已经尝试了 try catch
块,但它们似乎也没有用。我该怎么做?
我假定 id
是 table 的主键,因此您预计语句中不会超过 1 行:
SELECT iq FROM users WHERE id = $user_id
此语句的问题在于,如果 table 中不存在 $user_id
,它可能不会 return 任何行,因此在这种情况下 r.Read()
将 return false
和 while
循环中的代码永远不会被执行。
一种方法是使用聚合:
SELECT MAX(iq) AS iq FROM users WHERE id = $user_id
总是 return 一行:如果 $user_id
中不存在带有 id = $user_id
的 iq
行或 null
43=].
您还应该将 while
循环更改为:
if (r.Read()) {
.....................
}
或更好:
r.Read();
因为聚合查询保证 return 恰好 1 行。