- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试为 Grand Theft Auto V 修改构建一个脚本。这本质上是在线角色扮演服务器的毒贩工作。
我有以下界面:
namespace DrugDealer
{
public interface IDrugDealerJobRepository
{
DrugDealerJob GetJob(int jobId);
int CountJobs();
}
}
我有以下类(class):
namespace DrugDealer
{
public class DrugDealerJob
{
public int JobId { get; set; }
public string Drug { get; set; }
public int UnitBuyPrice { get; set; }
public int UnitSalePrice { get; set; }
public string Location { get; set; }
public string Vehicle { get; set; }
public string VehicleHash { get; set; }
public float X { get; set; }
public float Y { get; set; }
public float Z { get; set; }
}
}
我有以下类作为主要类:
using System;
using System.Collections.Generic;
using GTANetworkServer;
using Insight.Database;
using Insight.Database.Providers.MySql;
using MySql.Data.MySqlClient;
using Database;
using System.Threading;
namespace DrugDealer
{
public class Main : Script
{
private static MySqlConnectionStringBuilder _database;
private IUserRepository _userRepository;
private IDrugDealerJobRepository _drugDealerJobRepository;
public Main()
{
API.onResourceStart += API_onResourceStart;
}
private void API_onResourceStart()
{
API.consoleOutput("Starting DrugDealer!");
MySqlInsightDbProvider.RegisterProvider();
_database = new MySqlConnectionStringBuilder("");
_userRepository = _database.Connection().As<IUserRepository>();
_drugDealerJobRepository = _database.Connection().As<IDrugDealerJobRepository>();
ThreadStart drugDealerJob = new ThreadStart(StartDrugDealerJob);
Console.WriteLine("[" + DateTime.Now.ToLongTimeString() + "] Creating the drug dealer job thread");
Thread dealerJob = new Thread(drugDealerJob);
dealerJob.Start();
}
public void StartDrugDealerJob()
{
Console.WriteLine("[" + DateTime.Now.ToLongTimeString() + "] Dealer Job Starts thread");
// keep checking until players are on the server
PlayersOnServer();
int sleepfor = 5000; // 3600000 in one hour which we be using later
int i = 10;
while (i != 0)
{
List<Client> players = API.getAllPlayers();
foreach(Client player in players)
{
int numberOfJobs = _drugDealerJobRepository.CountJobs();
Console.WriteLine("[" + DateTime.Now.ToLongTimeString() + "] Number of Jobs: {0}", numberOfJobs);
DrugDealerJob currentJob = _drugDealerJobRepository.GetJob(new Random().Next(1, numberOfJobs));
Console.WriteLine("[" + DateTime.Now.ToLongTimeString() + "] A Drug Shipment of {0} has arrived at {1}. Look out for a {2}", currentJob.Drug, currentJob.Location, currentJob.Vehicle);
Console.WriteLine("[" + DateTime.Now.ToLongTimeString() + "] {0} has a job of {1}", player.name, _userRepository.GetAccount(player.name).Job);
if(_userRepository.GetAccount(player.name).Job != "Cop")
{
//API.sendChatMessageToPlayer(player, "A new shipment of {0} has arrived at the following location: {1}", );
}
}
Console.WriteLine("[" + DateTime.Now.ToLongTimeString() + "] Dealer Job thread Paused for {0} seconds", sleepfor / 1000);
Thread.Sleep(sleepfor);
Console.WriteLine("[" + DateTime.Now.ToLongTimeString() + "] Dealer Job thread resumes");
i--;
}
Console.WriteLine("[" + DateTime.Now.ToLongTimeString() + "] Dealer Job Ends thread");
}
public void PlayersOnServer()
{
// the thread is paused for 5000 milliseconds
int sleepfor = 5000;
List<Client> players;
// make thread loop endlessly until a user connects
do
{
players = API.getAllPlayers();
Console.WriteLine("[" + DateTime.Now.ToLongTimeString() + "] Checking Player Count: {0}", players.Count);
if (players.Count == 0)
Thread.Sleep(sleepfor);
} while (players.Count == 0);
}
}
}
当我在添加了资源的情况下运行服务器时,出现错误,并且当到达以下代码行时服务器崩溃:
int numberOfJobs = _drugDealerJobRepository.CountJobs();
我已从连接字符串中删除了敏感数据,但它工作正常,因为如果我删除导致错误的行,则以下行将按预期返回作业数据:
DrugDealerJob currentJob = _drugDealerJobRepository.GetJob(new Random().Next(1, numberOfJobs));
我似乎无法弄清楚如何使用 Visual Studio 来调试我的脚本。如果有人知道如何做到这一点,那么我将不胜感激。
应用程序通过接口(interface)连接到 mysql 数据库,该接口(interface)引用我在 mysql 数据库中创建的过程。
过程 CountJobs(无参数):
SELECT COUNT(*)
FROM drugdealerjobs
过程GetJob(参数jobid):
SELECT
t1.jobid
,t1.drug
,t1.unitbuyprice
,t1.unitsaleprice
,t1.location
,t1.vehicle
,t1.vehiclehash
,t2.x
,t2.y
,t2.z
FROM drugdealerjobs AS t1
INNER JOIN jobcoordinates AS t2
ON t1.jobid = t2.jobid
WHERE t1.jobid = jobid
你知道我可能做错了什么吗?我认为它与接口(interface)定义有关,但可以使用一些帮助。
非常感谢漫画编码器
最佳答案
在我看来,问题是 CountJobs
返回 int
。从CountJobs
返回System.Int64
可以解决这个问题。
1) CountJobs
应返回 System.Int64
。
2) 或者将ExecuteScalar
的返回值转换为int
。
count = Convert.ToInt32(cmd.ExecuteScalar());
如果这不能解决问题,能否请您分享一下这两种方法的实现。
DrugDealerJob GetJob(int jobId);
int CountJobs();
关于c# - 通过c#中的过程和接口(interface)统计mysql表中的行数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43956385/
我有一个包含未定义条目数的数据文件,如下所示: A B C D E.. 1 0 2 5 4 7 4 3 4 1 8 7 4 0 7 1 1 第一行代表工作时间,而不是暂停等交替方式。为了可
我需要有关小型 SQL 查询的帮助。考虑下表: TicketNo | Rules | Audit Result --------------------------------- P
我有一个非常大的表(~1 000 000 行)和带有联合、连接和 where 语句的复杂查询(用户可以选择不同的 ORDER BY 列和方向)。我需要获取分页的行数。如果我运行查询而不计算行数,它会很
我想获取数据帧的行数。 我可以通过 size(myDataFrame)[1] 实现这一点. 有更干净的方法吗? 最佳答案 如果您正在使用 DataFrames具体来说,那么你可以使用 nrow() :
是否可以在带有千位分隔符的 VIM 状态栏中显示行数,最好是自定义千位分隔符? 例子: set statusline=%L 应该导致“1,234,567”而不是“1234567”。 最佳答案 我找到了
我有一个非常基本的问题,但不知道该怎么做。如果 mysql 表中的行数增加,我想刷新页面。我已经尝试了一些不同的事情,比如在表中添加一个单独的列,如果行数和这个值相等,则值为 (id + 1),然后进
我的 mysql TB 中的行数(如 TB 信息中所示)是 11093,而自动递增 ID(从 1 开始)是 11361。为什么会这样? 最佳答案 删除的行不会重置 AI 索引。行数是当前表中的条目数,
我有一个 MySQL 表如下。 emp_no emp_name dob gender 1 A 1978-10-10 Male 2 B
ifstream inFile; inFile.open(filename); //open the input file stringstream strStream; strStream << i
SELECT * FROM table1 WHERE EXISTS (SELECT * FROM table2 WHERE *condition*) 例如,我可以检查是否有 3 行符合 table2
我正在尝试提取 SQL 表中的总行数。 我正在使用以下代码: $rowNum = mysql_query("SELECT COUNT(*) FROM Logs"); $count = mysql_fe
我想知道表格 View 的行宽是多少,UITableViewCell 文本标签的字体是什么,有人可以帮我吗? 最佳答案 NSLog(@"width: %f", cell.frame.size.widt
对于以下内容: def linecount(filename): count = 0 for x in open(filename): count += 1 r
感谢关注。 我用C语言写了一段代码来统计字数、行数和字符数。 while((c = fgetc(fp)) != EOF) { if((char)(c) == ' ' || (char)(c)
我是 matlab 的新手,只需要更改代码中的一个非常小的东西。我有以下矩阵: ans = 1 1 1 1 2 1 2 1
我只是想弄清楚如何确定行数,然后使该数字显示在 HTML 中。 我准备好的声明如下所示: if($stmt = $mysqli -> prepare("SELECT field1, field2, f
PDO 显然无法计算从选择查询返回的行数(mysqli 有 num_rows 变量)。 除了使用 count($results->fetchAll()) 之外,有没有办法做到这一点? 最佳答案 根据手
SELECT count(*) FROM Stack WHERE Id = 33478 GROUP BY SID Output: (No column name) 1 4 对于结果;有两排。怎么退货
IE。如果我们有一个包含400万行的表。 其中具有一个STATUS字段,该字段可以采用以下值:TO_WORK,BLOCKED或WORKED_CORRECTLY。 您是否会在一个仅会更改一次的字段上进行
所以在JTextArea中有一个getLineCount()是否有与JTextPane类似的东西,因为我可以找到任何东西。也许有不同的方法来获得它?我想获取当前存在的行数。 最佳答案 (正如您所指出的
我是一名优秀的程序员,十分优秀!