MySQL——插入20万条随机数据random_addinfo和索引功能

DDL

CREATE TABLE `亿万富翁表` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `birthday` date NOT NULL,
  `userName` varchar(100) NOT NULL,
  `countMoney` decimal(15,2) NOT NULL,
  `age` int(11) NOT NULL,
  `sex` varchar(10) NOT NULL,
  `address` varchar(200) NOT NULL,
  `introduce` text,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=600008 DEFAULT CHARSET=utf8;

DQL

DELIMITER //
ALTER TABLE `亿万富翁表` AUTO_INCREMENT = 1;

CREATE PROCEDURE random_addinfo()
BEGIN
    DECLARE i INT DEFAULT 0;
    WHILE i < 200000 DO
        INSERT INTO 亿万富翁表 (birthday, userName, countMoney, age, sex, address, introduce)
        VALUES (
            -- 生成随机的生日(例如:1900-01-01 到 2023-12-31 之间)
            FROM_UNIXTIME(UNIX_TIMESTAMP('1900-01-01') + FLOOR(RAND() * (UNIX_TIMESTAMP('2023-12-31') - UNIX_TIMESTAMP('1900-01-01') + 1))),
            -- 生成随机的用户名(假设用户名格式为 user1, user2, ..., userN)
            CONCAT('user', FLOOR(RAND() * 1000000)),
            -- 生成随机的资产(例如:1亿到1000亿之间)
            FLOOR(100000000 + RAND() * 99000000000),
            -- 生成随机的年龄(例如:20到90之间)
            FLOOR(20 + RAND() * 71),
            -- 随机分配性别
            IF(RAND() > 0.5, '男', '女'),
            -- 生成随机地址(这里简化为随机字符串,你可以根据需要自定义更复杂的地址生成逻辑)
            CONCAT('地址', FLOOR(RAND() * 1000000)),
            -- 生成随机介绍(同样简化为随机字符串)
            CONCAT('介绍', FLOOR(RAND() * 1000000))
        );
        SET i = i + 1;
    END WHILE;
END //

DELIMITER ;

call random_addinfo();

实验索引的能力

select count(*) from 亿万富翁表;

#实验索引的能力

select * from 亿万富翁表 where userName='user111642';

-- select * from 亿万富翁表 where userName='user111642'
-- > OK-无索引
-- > 时间: 0.237s


-- select * from 亿万富翁表 where userName='user111642'
-- > OK-有索引,所需时间缩短
-- > 时间: 0.003s
-- 

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
学生管理类(设计型题目) (1)创建C# 控制台应用程序L4_3。 (2)在程序中创建一个学生类Student,包含以下成员:  定义私有字段:学号s_no,姓名s_name, 班级s_class,成绩s_score。  定义Student类的构造函数,初始化4个私有字段。  定义四个公有属性S_no,S_name,S_class以及S_score,分别用于封装对各字段读写访问。 (3)再定义一个StudentInfo类,用于对学生信息进行管理:该类包括下列成员:  存放学生信息的Student[]类型的私有字段成员m_list ;  存储学生最大数量的私有字段m_maxcapacity;  存储当前学生数量的私有字段m_length;  带参数的构造函数,根据指定长度对各私有字段进行初始化。  定义类的只读公有属性:Maxcapcity属性、Currentlength属性、 Restlength属性,分别用于返回列表的最大容量、已存信息的容量、剩余的最大容量。  定义一个索引函数,用于实现根据学生的学号对信息进行读、写访问。(无论读或写操作都要求先判断学生是否存在)。  定义公有方法AddInfo(返回类型为bool),用于向学生信息列表中添加学生信息(需要判断添加操作能否进行,即列表是否已满)。  定义一个公有方法DeleteInfo返回类型为bool),用于根据学生学号删除信息。(需要判断学生是否存在) (4)在外部类中进行StudentInfo类的各种功能进行测试。
用VS编写的FTP服务器软件,C#网络程序编程学习用。 代码: using System; using System.Collections.Generic; using System.Globalization; using System.IO; using System.Net; using System.Net.Sockets; using System.Threading; using System.Windows.Forms; namespace FtpServer { public partial class FtpServerForm : Form { TcpListener myTcpListener = null; private Thread listenThread; // 保存用户名和密码 Dictionary users; public FtpServerForm() { InitializeComponent(); // 初始化用户名和密码 users = new Dictionary(); users.Add("admin", "admin"); // 设置默认的主目录 tbxFtpRoot.Text = "F:/MyFtpServerRoot/"; IPAddress[] ips = Dns.GetHostAddresses(""); tbxFtpServerIp.Text = ips[5].ToString(); tbxFtpServerPort.Text = "21"; lstboxStatus.Enabled = false; } // 启动服务器 private void btnFtpServerStartStop_Click(object sender, EventArgs e) { if (myTcpListener == null) { listenThread = new Thread(ListenClientConnect); listenThread.IsBackground = true; listenThread.Start(); lstboxStatus.Enabled = true; lstboxStatus.Items.Clear(); lstboxStatus.Items.Add("已经启动Ftp服务..."); btnFtpServerStartStop.Text = "停止"; } else { myTcpListener.Stop(); myTcpListener = null; listenThread.Abort(); lstboxStatus.Items.Add("Ftp服务已停止!"); lstboxStatus.TopIndex = lstboxStatus.Items.Count - 1; btnFtpServerStartStop.Text = "启动"; } } // 监听端口,处理客户端连接 private void ListenClientConnect() { myTcpListener = new TcpListener(IPAddress.Parse(tbxFtpServerIp.Text), int.Parse(tbxFtpServerPort.Text)); // 开始监听传入的请求 myTcpListener.Start(); AddInfo("启动FTP服务成功!"); AddInfo("Ftp服务器运行中...[点击”停止“按钮停止FTP服务]"); while (true) { try { // 接收连接请求 TcpClient tcpClient = myTcpListener.AcceptTcpClient(); AddInfo(string.Format("客户端({0})与本机({1})建立Ftp连接", tcpClient.Client.RemoteEndPoint, myTcpListener.LocalEndpoint)); User user = new User(); user.commandSession = new UserSeesion(tcpClient); user.workDir = tbxFtpRoot.Text; Thread t = new Thread(UserProcessing); t.IsBackground = true; t.Start(user); } catch { break; } } } // 处理客户端用户请求 private void UserProcessing(object obj) { User user = (User)obj; string sendString = "220 FTP Server v1.0"; RepleyCommandToUser(user, sendString); while (true) { string receiveString = null; try { // 读取客户端发来的请求信息 receiveString = user.commandSession.streamReader.ReadLine(); } catch(Exception ex) { if (user.commandSession.tcpClient.Connected == false) { AddInfo(string.Format("客户端({0}断开连接!)", user.commandSession.tcpClient.Client.RemoteEndPoint)); } else { AddInfo("接收命令失败!" + ex.Message); } break; } if (receiveString == null) { AddInfo("接收字符串为null,结束线程!"); break; } AddInfo(string.Format("来自{0}:[{1}]", user.commandSession.tcpClient.Client.RemoteEndPoint, receiveString)); // 分解客户端发来的控制信息中的命令和参数 string command = receiveString; string param = string.Empty; int index = receiveString.IndexOf(' '); if (index != -1) { command = receiveString.Substring(0, index).ToUpper(); param = receiveString.Substring(command.Length).Trim(); } // 处理不需登录即可响应的命令(这里只处理QUIT) if (command == "QUIT") { // 关闭TCP连接并释放与其关联的所有资源 user.commandSession.Close(); return; } else { switch (user.loginOK) { // 等待用户输入用户名: case 0: CommandUser(user, command, param); break; // 等待用户输入密码 case 1: CommandPassword(user, command, param); break; // 用户名和密码验证正确后登陆 case 2: switch (command) { case "CWD": CommandCWD(user, param); break; case "PWD": CommandPWD(user); break; case "PASV": CommandPASV(user); break; case "PORT": CommandPORT(user, param); break; case "LIST": CommandLIST(user, param); break; case "NLIST": CommandLIST(user, param); break; // 处理下载文件命令 case "RETR": CommandRETR(user, param); break; // 处理上传文件命令 case "STOR": CommandSTOR(user, param); break; // 处理删除命令 case "DELE": CommandDELE(user, param); break; // 使用Type命令在ASCII和二进制模式进行变换 case "TYPE": CommandTYPE(user, param); break; default: sendString = "502 command is not implemented."; RepleyCommandToUser(user, sendString); break; } break; } } } } // 想客户端返回响应码 private void RepleyCommandToUser(User user, string str) { try { user.commandSession.streamWriter.WriteLine(str); AddInfo(string.Format("向客户端({0})发送[{1}]", user.commandSession.tcpClient.Client.RemoteEndPoint, str)); } catch { AddInfo(string.Format("向客户端({0})发送信息失败", user.commandSession.tcpClient.Client.RemoteEndPoint)); } } // 向屏幕输出显示状态信息(这里使用了委托机制) private delegate void AddInfoDelegate(string str); private void AddInfo(string str) { // 如果调用AddInfo()方法的线程与创建ListView控件的线程不在一个线程时 // 此时利用委托在创建ListView的线程上调用 if (lstboxStatus.InvokeRequired == true) { AddInfoDelegate d = new AddInfoDelegate(AddInfo); this.Invoke(d, str); } else { lstboxStatus.Items.Add(str); lstboxStatus.TopIndex = lstboxStatus.Items.Count - 1; lstboxStatus.ClearSelected(); } } #region 处理各个命令 #region 登录过程,即用户身份验证过程 // 处理USER命令,接收用户名但不进行验证 private void CommandUser(User user, string command, string param) { string sendString = string.Empty; if (command == "USER") { sendString = "331 USER command OK, password required."; user.userName = param; // 设置loginOk=1为了确保后面紧接的要求输入密码 // 1表示已接收到用户名,等到接收密码 user.loginOK = 1; } else { sendString = "501 USER command syntax error."; } RepleyCommandToUser(user, sendString); } // 处理PASS命令,验证用户名和密码 private void CommandPassword(User user, string command, string param) { string sendString = string.Empty; if (command == "PASS") { string password = null; if (users.TryGetValue(user.userName, out password)) { if (password == param) { sendString = "230 User logged in success"; // 2表示登录成功 user.loginOK = 2; } else { sendString = "530 Password incorrect."; } } else { sendString = "530 User name or password incorrect."; } } else { sendString = "501 PASS command Syntax error."; } RepleyCommandToUser(user, sendString); // 用户当前工作目录 user.currentDir = user.workDir; } #endregion #region 文件管理命令 // 处理CWD命令,改变工作目录 private void CommandCWD(User user, string temp) { string sendString = string.Empty; try { string dir = user.workDir.TrimEnd('/') + temp; // 是否为当前目录的子目录,且不包含父目录名称 if (Directory.Exists(dir)) { user.currentDir = dir; sendString = "250 Directory changed to '" + dir + "' successfully"; } else { sendString = "550 Directory '" + dir + "' does not exist"; } } catch { sendString = "502 Directory changed unsuccessfully"; } RepleyCommandToUser(user,sendString); } // 处理PWD命令,显示工作目录 private void CommandPWD(User user) { string sendString = string.Empty; sendString = "257 '" + user.currentDir + "' is the current directory"; RepleyCommandToUser(user, sendString); } // 处理LIST/NLIST命令,想客户端发送当前或指定目录下的所有文件名和子目录名 private void CommandLIST(User user, string parameter) { string sendString = string.Empty; DateTimeFormatInfo dateTimeFormat = new CultureInfo("en-US", true).DateTimeFormat; // 得到目录列表 string[] dir = Directory.GetDirectories(user.currentDir); if (string.IsNullOrEmpty(parameter) == false) { if (Directory.Exists(user.currentDir + parameter)) { dir = Directory.GetDirectories(user.currentDir + parameter); } else { string s = user.currentDir.TrimEnd('/'); user.currentDir = s.Substring(0, s.LastIndexOf("/") + 1); } } for (int i = 0; i < dir.Length; i++) { string folderName = Path.GetFileName(dir[i]); DirectoryInfo d = new DirectoryInfo(dir[i]); // 按下面的格式输出目录列表 sendString += @"dwr-\t" + Dns.GetHostName() + "\t" + dateTimeFormat.GetAbbreviatedMonthName(d.CreationTime.Month) + d.CreationTime.ToString(" dd yyyy") + "\t" + folderName + Environment.NewLine; } // 得到文件列表 string[] files = Directory.GetFiles(user.currentDir); if (string.IsNullOrEmpty(parameter) == false) { if (Directory.Exists(user.currentDir + parameter + "/")) { files = Directory.GetFiles(user.currentDir + parameter + "/"); } } for (int i = 0; i 1024的随机端口 // 下面这个运算算法只是为了得到一个大于1024的端口值 port = random1 << 8 | random2; try { user.dataListener = new TcpListener(localip, port); AddInfo("TCP 数据连接已打开(被动模式)--" + localip.ToString() + ":" + port); } catch { continue; } user.isPassive = true; string temp = localip.ToString().Replace('.', ','); // 必须把端口号IP地址告诉客户端,客户端接收到响应命令后, // 再通过新的端口连接服务器的端口P,然后进行文件数据传输 sendString = "227 Entering Passive Mode(" + temp + "," + random1 + "," + random2 + ")"; RepleyCommandToUser(user, sendString); user.dataListener.Start(); break; } } // 处理PORT命令,使用主动模式进行传输 private void CommandPORT(User user, string portstring) { // 主动模式时,客户端必须告知服务器接收数据的端口号,PORT 命令格式为:PORT address // address参数的格式为i1、i2、i3、i4、p1、p2,其中i1、i2、i3、i4表示IP地址 // 下面通过.字符串来组合这四个参数得到IP地址 // p1、p2表示端口号,下面通过int.Parse(temp[4]) << 8) | int.Parse(temp[5] // 这个算法来获得一个大于1024的端口来发送给服务器 string sendString = string.Empty; string[] temp = portstring.Split(','); string ipString = "" + temp[0] + "." + temp[1] + "." + temp[2] + "." + temp[3]; // 客户端发出PORT命令把客户端的IP地址和随机的端口告诉服务器 int portNum = (int.Parse(temp[4]) < 0) { user.dataSession.binaryWriter.Write(bytes, 0, count); user.dataSession.binaryWriter.Flush(); count = binaryReader.Read(bytes, 0, bytes.Length); } } else { StreamReader streamReader = new StreamReader(fs); while (streamReader.Peek() > -1) { user.dataSession.streamWriter.WriteLine(streamReader.ReadLine()); } } AddInfo("...]发送完毕!"); } finally { user.dataSession.Close(); fs.Close(); } } // 使用数据连接接收文件流(客户端发送上传文件功能) private void ReadFileByUserSession(User user, FileStream fs) { AddInfo("接收用户上传数据(文件流):[..."); try { if (user.isBinary) { byte[] bytes = new byte[1024]; BinaryWriter binaryWriter = new BinaryWriter(fs); int count = user.dataSession.binaryReader.Read(bytes, 0, bytes.Length); while (count > 0) { binaryWriter.Write(bytes, 0, count); binaryWriter.Flush(); count = user.dataSession.binaryReader.Read(bytes, 0, bytes.Length); } } else { StreamWriter streamWriter = new StreamWriter(fs); while (user.dataSession.streamReader.Peek() > -1) { streamWriter.Write(user.dataSession.streamReader.ReadLine()); streamWriter.Flush(); } } AddInfo("...]接收完毕"); } finally { user.dataSession.Close(); fs.Close(); } } private void label3_Click(object sender, EventArgs e) { } } }
以前用wpf写的地震体浏览工具,还有不完善的地方,借以抛砖引玉。 欢迎交流。 namespace WpfPtest { /// <summary> /// Interaction logic for Window1.xaml /// </summary> public partial class Window1 : Window { private CA_SegY.CSegY m_CSegy = new CA_SegY.CSegY(); //private CA_SegY.CSegYScanner m_CSegyScan = new CA_SegY.CSegYScanner(); public Window1() { InitializeComponent(); } private void BtnOpenFile_Click(object sender, RoutedEventArgs e) { OpenFileDialog openSegyFile = new OpenFileDialog(); openSegyFile.ShowDialog(); text_SegyFilePath.Text = openSegyFile.FileName; // string strValue = m_CSegy.GetProtectedStr(); // string strValueTest = m_CSegyScan.GetProtectedStr(); // strValueTest = m_CSegyScan.getValue(); m_CSegy.SetSegyFile(openSegyFile.FileName); m_CSegy.OpenSegyFile(); // m_CSegyScan.SetSegyFile(openSegyFile.FileName); // m_CSegyScan.OpenSegyFile(); ShowSegyFileHeader(); } private void BtnExit_Click(object sender, RoutedEventArgs e) { Close(); } private void ShowSegyFileHeader() { if (null == m_CSegy) { return; } ShowSegyEbcdicHeader(); ShowSegyBinaryHeader(); //ShowSegyTraceInfo(1); } private void ShowSegyEbcdicHeader() { if (null == m_CSegy) { return; } string strEbcdic = ""; strEbcdic = m_CSegy.GetSegyEbcdicHeader(); richTextBox1.AppendText(strEbcdic); } private void ShowSegyBinaryHeader() { if (null == m_CSegy) { return; } CA_SegY.c_SEGYBinary_Header segyBinaryHeader = new CA_SegY.c_SEGYBinary_Header(); segyBinaryHeader = m_CSegy.GetSegyBinaryHeader(); txtSamples.Text = (segyBinaryHeader.hns).ToString();//hns txtSampleRate.Text = (segyBinaryHeader.hdt).ToString() + "ms"; txtTraces.Text = (m_CSegy.GetTracesCount()).ToString(); txtFormatCode.Text = m_CSegy.GetUnitType().ToString(); labelMax.Content = txtTraces.Text; slider1.Maximum = m_CSegy.GetTracesCount(); slider1.Minimum = 1; CoustomSegyBinaryHeader segybinaryheader = new CoustomSegyBinaryHeader(); segybinaryheader.AddInfo("1-4", (segyBinaryHeader.jobid).ToString(), "作业标识号"); segybinaryheader.AddInfo("5-8", (segyBinaryHeader.lino).ToString(), "测线号"); segybinaryheader.AddInfo("9-12", (segyBinaryHeader.reno).ToString(), "卷号"); segybinaryheader.AddInfo("13-14", (segyBinaryHeader.ntrpr).ToString(), "道数"); segybinaryheader.AddInfo("15-16", (segyBinaryHeader.nart).ToString(), "辅助道数"); segybinaryheader.AddInfo("17-18", (segyBinaryHeader.hdt).ToString(), "采样间隔"); segybinaryheader.AddInfo("19-20", (segyBinaryHeader.dto).ToString(), "野外记录间隔"); segybinaryheader.AddInfo("21-22", (segyBinaryHeader.hns).ToString(), "每道样点数"); segybinaryheader.AddInfo("23-24", (segyBinaryHeader.nso).ToString(), "野外记录道的样点数"); segybinaryheader.AddInfo("25-26", (segyBinaryHeader.format).ToString(), "数据格式码"); segybinaryheader.AddInfo("27-28", (segyBinaryHeader.fold).ToString(), "CMP覆盖次数"); segybinaryheader.AddInfo("29-30", (segyBinaryHeader.tsort).ToString(), "道分选码"); segybinaryheader.AddInfo("31-32", (segyBinaryHeader.vscode).ToString(), "垂直叠加码"); segybinaryheader.AddInfo("33-34", (segyBinaryHeader.hsfs).ToString(), "起始扫描频率"); segybinaryheader.AddInfo("35-36", (segyBinaryHeader.hsfe).ToString(), "终止扫描频率"); segybinaryheader.AddInfo("37-38", (segyBinaryHeader.hslen).ToString(), "扫描长度"); segybinaryheader.AddInfo("39-40", (segyBinaryHeader.hstyp).ToString(), "扫描类型码"); segybinaryheader.AddInfo("41-42", (segyBinaryHeader.schn).ToString(), "扫描通道的道号"); segybinaryheader.AddInfo("43-44", (segyBinaryHeader.hstas).ToString(), "有斜坡时,为起始斜坡长度(斜坡起始于时间零,使用时间为该长度)。以 ms 表示。"); segybinaryheader.AddInfo("45-46", (segyBinaryHeader.hstae).ToString(), "终了斜坡长度(终了斜坡起始于扫描长度减终了斜坡长度)。以 ms 表示。"); segybinaryheader.AddInfo("47-48", (segyBinaryHeader.htatyp).ToString(), "斜坡类型"); segybinaryheader.AddInfo("49-50", (segyBinaryHeader.hcorr).ToString(), "相关数据道"); segybinaryheader.AddInfo("51-52", (segyBinaryHeader.bgrcv).ToString(), "二进制增益恢复"); segybinaryheader.AddInfo("53-54", (segyBinaryHeader.rcvm).ToString(), "振幅恢复方式"); segybinaryheader.AddInfo("55-56", (segyBinaryHeader.mfeet).ToString(), "测量系统"); segybinaryheader.AddInfo("57-58", (segyBinaryHeader.polyt).ToString(), "脉冲信号极性"); segybinaryheader.AddInfo("59-60", (segyBinaryHeader.vpol).ToString(), "可控震源 地震信号滞"); segybinaryheader.AddInfo("61-62", (segyBinaryHeader.traceNum).ToString(), "总道数"); segybinaryheader.AddInfo("69-70", (segyBinaryHeader.sampletype).ToString(), "数据域(性质):0-时域,1-振幅,2-相位谱"); segybinaryheader.AddInfo("271-400", "", "没有确定,选择使用 "); ListViewBinary.ItemsSource = segybinaryheader; } private void ShowSegyTraceInfo(int iNo) { if(null == m_CSegy) { return; } CA_SegY.c_SEGYTrace_Info segyTraceHeader = new CA_SegY.c_SEGYTrace_Info(); float[] segyTraceData = new float[m_CSegy.GetTraceSample()]; if (!m_CSegy.getTraceInfo(iNo, ref segyTraceHeader, segyTraceData)) { return; }
1. 设计数据库 首先需要设计数据库,假设有两张表:用户信息表和用户发布信息表。 用户信息表包括以下字段: | 字段名 | 类型 | 描述 | | ---------- | -------- | -------- | | user_id | int | 用户ID | | user_name | varchar | 用户名 | | user_pass | varchar | 用户密码 | | user_level | int | 用户等级 | 用户发布信息表包括以下字段: | 字段名 | 类型 | 描述 | | -------------- | --------- | ---------------- | | info_id | int | 信息ID | | user_id | int | 用户ID | | info_title | varchar | 信息标题 | | info_content | varchar | 信息内容 | | info_time | datetime | 信息发布时间 | | info_is_passed | tinyint | 信息是否已审批 | | info_is_delete | tinyint | 信息是否已删除 | 2. 编写后端代码 使用SSM框架编写后端代码,具体步骤如下: 1.创建User和Info的实体类 ``` public class User { private int user_id; private String user_name; private String user_pass; private int user_level; //省略getter和setter方法 } public class Info { private int info_id; private int user_id; private String info_title; private String info_content; private Date info_time; private int info_is_passed; private int info_is_delete; //省略getter和setter方法 } ``` 2.创建User和Info的Mapper接口 ``` public interface UserMapper { User selectUserById(int user_id); } public interface InfoMapper { List<Info> selectAllInfoByUserId(int user_id); Info selectInfoById(int info_id); void insertInfo(Info info); void updateInfo(Info info); } ``` 3.创建User和Info的Service接口和实现类 ``` public interface UserService { User getUserById(int user_id); } @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public User getUserById(int user_id) { return userMapper.selectUserById(user_id); } } public interface InfoService { List<Info> getAllInfoByUserId(int user_id); Info getInfoById(int info_id); void addInfo(Info info); void updateInfo(Info info); } @Service public class InfoServiceImpl implements InfoService { @Autowired private InfoMapper infoMapper; @Override public List<Info> getAllInfoByUserId(int user_id) { return infoMapper.selectAllInfoByUserId(user_id); } @Override public Info getInfoById(int info_id) { return infoMapper.selectInfoById(info_id); } @Override public void addInfo(Info info) { infoMapper.insertInfo(info); } @Override public void updateInfo(Info info) { infoMapper.updateInfo(info); } } ``` 4.创建Controller类 ``` @Controller @RequestMapping("/info") public class InfoController { @Autowired private UserService userService; @Autowired private InfoService infoService; @RequestMapping("/list") public String list(Model model, HttpSession session) { int user_id = (int) session.getAttribute("user_id"); List<Info> infoList = infoService.getAllInfoByUserId(user_id); model.addAttribute("infoList", infoList); return "info_list"; } @RequestMapping("/add") public String add(Model model) { model.addAttribute("info", new Info()); return "info_add"; } @RequestMapping("/save") public String save(@ModelAttribute("info") Info info, HttpSession session) { int user_id = (int) session.getAttribute("user_id"); info.setUser_id(user_id); info.setInfo_time(new Date()); info.setInfo_is_passed(0); // 初始状态为未审批 info.setInfo_is_delete(0); // 初始状态为未删除 infoService.addInfo(info); return "redirect:/info/list"; } @RequestMapping("/edit") public String edit(@RequestParam("info_id") int info_id, Model model) { Info info = infoService.getInfoById(info_id); model.addAttribute("info", info); return "info_edit"; } @RequestMapping("/update") public String update(@ModelAttribute("info") Info info) { infoService.updateInfo(info); return "redirect:/info/list"; } } ``` 3. 编写前端代码 使用HTML和Thymeleaf模板引擎编写前端代码,具体步骤如下: 1.创建信息列表页面(info_list.html) ``` <!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>信息列表</title> </head> <body> <table> <thead> <tr> <th>ID</th> <th>标题</th> <th>内容</th> <th>发布时间</th> <th>审批状态</th> <th>操作</th> </tr> </thead> <tbody> <tr th:each="info : ${infoList}"> <td th:text="${info.info_id}"></td> <td th:text="${info.info_title}"></td> <td th:text="${info.info_content}"></td> <td th:text="${info.info_time}"></td> <td th:text="${info.info_is_passed == 0 ? '未审批' : '已审批'}"></td> <td> <a th:href="@{/info/edit(info_id=${info.info_id})}">编辑</a> </td> </tr> </tbody> </table> <a th:href="@{/info/add}">添加信息</a> </body> </html> ``` 2.创建添加信息页面(info_add.html) ``` <!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>添加信息</title> </head> <body> <form th:action="@{/info/save}" th:object="${info}" method="post"> <label>标题:</label> <input type="text" th:field="*{info_title}"><br> <label>内容:</label> <textarea th:field="*{info_content}"></textarea><br> <input type="submit" value="保存"> </form> </body> </html> ``` 3.创建编辑信息页面(info_edit.html) ``` <!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>编辑信息</title> </head> <body> <form th:action="@{/info/update}" th:object="${info}" method="post"> <input type="hidden" th:field="*{info_id}"> <label>标题:</label> <input type="text" th:field="*{info_title}"><br> <label>内容:</label> <textarea th:field="*{info_content}"></textarea><br> <input type="submit" value="保存"> </form> </body> </html> ``` 至此,使用SSM框架实现管理员对用户发布的信息具有审批和撤销功能的代码就完成了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值