Search for a stored procedure

本文介绍了如何在SQL Server 2005中查找特定表被使用的存储过程,搜索存储过程的方法,以及在不使用sp_depends的情况下进行对象依赖检查的技巧。
September 3, 2007 by Pinal Dave
SQL SERVER – 2005 – Search Stored Procedure Code – Search Stored Procedure Text

I receive following question many times by my team members.

How can I find if particular table is being used in the stored procedure?
How to search in stored procedures?
How can I do dependency check for objects in stored procedure without using sp_depends?

I have previously wrote article about this SQL SERVER – Find Stored Procedure Related to Table in Database – Search in All Stored procedure.

The same feature can be implemented using following script in SQL Server 2005.
USE AdventureWorks
GO
--Searching for Empoloyee table
SELECT Name
FROM sys.procedures
WHERE OBJECT_DEFINITION(OBJECT_ID) LIKE '%Employee%'
GO
--Searching for Empoloyee table and RateChangeDate column together
SELECT Name
FROM sys.procedures
WHERE OBJECT_DEFINITION(OBJECT_ID) LIKE '%Employee%'
AND OBJECT_DEFINITION(OBJECT_ID) LIKE '%RateChangeDate%'
GO
ResultSet:
Name
———————————–
uspGetEmployeeManagers
uspGetManagerEmployees
uspUpdateEmployeeHireInfo
uspUpdateEmployeeLogin
uspUpdateEmployeePersonalInfo

Name
———————————–
uspUpdateEmployeeHireInfo

Reference : Pinal Dave (http://blog.SQLAuthority.com)
package org.uob.a1这个是我要写代码的那个文件夹 The University of Birmingham School of Computer Science Assignment 1 – Text Based Game Deadline: 16:00, Nov 10, 2025 Author: Pieter Joubert Reviewers: Jon Rowe Ahmad Ibrahim Wendy Yanez Sergey Goncharov Version 2.5 An Assignment submitted for the UoB: Object Oriented Programming October 20, 2025 Start of the revision history table Revision History Revision Date Author(s) Description 1.0 19/10/2025 PJ Initial version. 1.1 23/10/2025 PJ Minor updates and corrections 1 Contents 1 Introduction 4 2 Mark allocations 4 2.1 2.2 Minimum expected commands . . . . . . . . . . . . . . . . . . . . . . 4 Additional commands . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 2.3 Minimum game requirements . . . . . . . . . . . . . . . . . . . . . . . 5 3 Task 1 - Position.java 5 4 Task 2 - Room.java 6 5 Task 3 - Map.java 6 6 Task 4 - Inventory.java 6 7 Task 5 - Score.java 7 8 Task 6 - Game.java 7 9 Submission Procedure 8 10 Rubric 8 11 Sample Output 9 2 *Rules* 1. For each class refer to its corresponding test to verify field and method naming conventions. 2. Although there are many ways to construct an application, you are required to adhere to the rules stipulated below (to achieve marks). 3. If variable names are not stipulated, you can use your own names for variables. This shows that you have written the application (we will check for plagiarism). 4. Inclusion of extra imports is strictly prohibited and will lead to a substantial penalty. You are restricted from using external libraries or any libraries that are not pre-included in the provided skeleton code. 5. Do NOT change or modify files included in the "test", "lib" or "out" folders. 6. Do NOT modify the template code. However, you are allowed to create your own methods if they are needed. 7. You MUST complete this assignment independently, producing your own code – Do NOT discuss or share your code with others. Any use of external generative- AI or code source is prohibited. Any cheating behaviour will result in a zero score for this module and will be subject to punishment by the University. 8. It is *STRONGLY ADVISED AGAINST* utilizing any translation software (such as Google Translate) for the translation of this document. 9. The jUnit tests included in the skeleton code are basic and only scratch the surface in evaluating your code. Passing these tests does not guarantee a full mark. 10. Wrong file structure leads to a substantial penalty. Make sure you have followed the Submission Instructions on the Assignment 1 Canvas page. 11. Make sure you complete all the required sections. 12. Make sure you have pushed the version of your code that you want marked to gitlab. 3 1 Introduction In this assignment, you are tasked with creating a basic text-based game in the style of Zork (https://en.wikipedia.org/wiki/Zork) The game is played by the user entering in various commands (e.g. "move south", "look", "search chest", "get key"), to which the game responds with text based output (e.g. "You pick up the rusty key"). You need to create your own narrative or story for the game. This narrative can be of any genre: science-fiction, cosy cooking game, fantasy, detective noir, etc. The game consists of "rooms" or "areas" which the player can travel to and perform actions in. Your game also needs to present puzzles to the player. Puzzles involve the player using an item in their inventory. The game will also provide the player with a score based on how many "rooms" they have visited and how many puzzles they have solved. Finally, the game also needs to display a text-based map of the game world as the player is exploring. 2 Mark allocations You will receive marks based on two aspects of the game: Firstly, the results of running the test.sh command. We will run our own version of these tests once you have submit- ted. This command will test each class and method (detailed as Task 1 - 6). You need to implement all the classes and methods shown in the Task sections. Secondly, you will need to submit a screen recording showing you playing the game and discussing the code. Your screen recording needs to have the following: • Show your face and your student card or any other valid proof of identity (e.g. Passport or drivers license). • Play through the game once showing all the rooms, puzzles and an example of each of the expected commands. Do this in the order given in Section 2.1 • Show and briefly explain the code in your Game.java file. • Show and briefly explain anything additional, innovative, or interesting you did in the game. The screen recording must be shorter than 5 minutes. You can use a text-to-speech app if you do not want to record your own voice. 2.1 Minimum expected commands The following is a minimum list of commands the game must be able to parse (values in angle brackets refer to arguments given to a command): 4 • "move <direction>" - (<direction> can be "north", "south", "east", "west"). The player moves to a new room based on the direction. • "look" - Displays a description of the room the player is in. • "look <feature>" - Displays a more detailed description of a feature in a room. A feature is a fixed object in the room. • "look <item>" - Displays a description of an item. This should only work if the item is in the player’s inventory. • "inventory" - Displays a list of all items the player has obtained. • "score" - Displays the user’s current score. • "map" - Displays a text-based map of the current explored game world. • "help" - Displays a help message. • "quit" - Quits the game. 2.2 Additional commands You need to add additional commands of your choice for the puzzles you will create. For example, "open toolbox" will open a toolbox. Then "take crowbar" will take the crowbar out of the toolbox and put it into the user’s inventory. You can create any other additional commands you want so long as they make log- ical sense in your game. You need to use these additional commands to create your puzzles. 2.3 Minimum game requirements The following are the minimum requirements for the game. You are welcome to add more if you want to: • At least ten (10) unique rooms or areas. • At least two (2) puzzles. • At least four (4) items. 3 Task 1 - Position.java The Position class stores an position in terms of an x and y value. The required methods are: • public Position(int x, int y) The x and y fields need to be declared as public so that other classes can access them directly. 5 4 Task 2 - Room.java The Room class stores information about a Room, including a name, description, a symbol and a Position. The required methods are: • public Room(String name, String description, char symbol, Position position) • public String getName() • public String getDescription() • public char getSymbol() • public Position getPosition() The symbol is used when displaying the room on the map. 5 Task 3 - Map.java The Map class stores information about the game Map, including the map array, a width and height, and the value used for empty map areas. The required methods are: • public Map(int width, int height) (this represents the rows and columns starting at the top left of the map) • public void placeRoom(Position pos, char symbol) • public String display() Declare the empty area value as follows: final private char EMPTY =' . '; 6 Task 4 - Inventory.java The Inventory class stores the player’s inventory, and is essentially a wrapper around an array. It includes the maximum items you can store, the current number of items stored and an array to store the items in. The required methods are: • public Inventory() • public void addItem(String item) Adds an item to the array if there is space. • public int hasItem(String item) Returns the position of the item in the array if it is in the array. Otherwise it returns -1 6 • public void removeItem(String item) Removes a specified item while ensuring there are no empty elements in the array. • public String displayInventory() Returns a String of all items sepa- rated by spaces (note that there is a space after the last item as well). Declare the maximum size as follows: final int MAX_ITEMS = 10; 7 Task 5 - Score.java The Score class stores and calculates the player’s score. It includes the starting score, the current score, the number of rooms visited, the number of puzzles solved and the score per puzzle. The required methods are: • public Score(int startingScore) • public void visitRoom() • public void solvePuzzle() • public double getScore() Calculates and returns the current score. The score is calculated as the starting score minus the number of rooms visited plus the number of solved puzzles times the score per puzzle. Declare the score per puzzle as follows: private final int PUZZLE_VALUE = 10; 8 Task 6 - Game.java The Game class runs the main game loop. You can create any methods you feel you require but you need to use all the other classes to make the game work. The only required method is: • public static void main(String[] args) You can write this code in any way you want to but here is a hint for a possible approach: • Create some Room objects to store information about each Room in your game. • Create Inventory and Score objects. • Use a while loop for the main game loop. • Inside this loop use an if statement to check what commands the user has typed. Based on the command, the Room the user is in and what items the user has in their inventory output a different response and update the Inventory, Score and Map information if appropriate. 7 9 Submission Procedure The general steps to take to complete the project are as follows: • Set up your gitlab ssh access using the setup-git command on vlab. • Copy your ssh key to your gitlab profile. • Clone the template repository from your gitlab. • Do not change any of the code in the template but you may add to it. • Work on your code, testing it regularly. Use the run.sh script to run the code as this builds the code correctly as well. • Use the test.sh script to test your code. This will give you an output similar to what we will use to mark the code. • Make sure you commit and push regularly as well. • Make sure to add comments to your code to clearly explain what each method is doing. • Once you have completed the code, record a short video using MS Stream. Refer to Section 2 for more information. • Submit the video to canvas. • Submit the latest commit hash to canvas. • You will receive an automated message indicating whether we are able to mark your code. • If there are no problems you are done with the assignment. • If there are problems with your submission, update it accordingly and resubmit the latest commit hash. 10 Rubric Task Submission Type Mark Position.java Room.java Map.java Inventory Score Game playthrough Game.java Additional features gitlab 5 gitlab gitlab gitlab gitlab Canvas video submission Canvas video submission Canvas video submission 10 10 15 10 20 15 15 Total 100 Table 2: Mark Rubric 8 11 Sample Output Your empty cell in the brig. The only notable feature is the half open cell door to the south. >> move south You follow the hallway south >> move south You follow the hallway towards the control room >> look You are standing in the control room of the brig. There is a control panel with a number of large button with ’locked’ written on it. >> press button You press the button marked ’locked’ . >> look You are standing in the control room of the brig. There is a control panel with a number of large button with ’unlocked’ now written on it. The lock on the door to the east is open. >> move east You go east. >> look You are standing in a dark and dusty storage room. You notice a closed toolbox standing on a crate. There is a metal grate in the corner of the room. >> inventory You have: >> map .......... .c........ .h........ .bs....... .......... .......... .......... .......... .......... .......... >> open toolbox You open the toolbox. Inside you find a crowbar. >> take crowbar You take the crowbar. >> inventory You have: crowbar >> use crowbar on grate You lift the grate up. A ladder leads down into darkness. >> look You are standing in a dark and dusty storage room. You notice a open and empty toolbox standing on a crate. There is a open metal grate in the corner of the room. >> help 9 Valid commands are: <look>, <move> <direction>, <look feature>, <look item>, <help>, <inventory>, <map>, <score> and <quit> >> score SCORE: 106.0 >> quit Game over 10这些是要求给我生成代码。
最新发布
11-09
<think>好的,我现在需要帮用户根据他们的需求生成代码。他们提到的是一个文本游戏,基于Zork风格,需要完成多个任务,包括Position.java、Room.java、Map.java等类,以及Game.java的主循环。用户还提供了详细的任务描述和评分标准,看起来这是一个大学课程的作业。 首先,我需要仔细阅读用户提供的文档,确保每个类的方法和要求都被正确实现。例如,Position类需要有公共的x和y字段,Room类需要存储名称、描述、符号和位置,并且有对应的getter方法。Map类需要处理二维数组来表示地图,Inventory类需要管理物品的增删和显示,Score类计算分数,最后Game.java整合所有内容。 接下来,我需要考虑各个类之间的关联。例如,Game类会使用到Map、Room、Inventory、Score等对象。在Game的主循环中,需要处理用户输入的命令,比如move、look、inventory等,并根据当前房间的状态和玩家的物品做出反应。 用户可能遇到的困难包括如何处理地图的显示,特别是如何在移动时更新地图的标记,以及如何管理房间之间的连接。另外,Inventory类中的添加、删除物品需要维护数组,可能需要处理数组扩容或移动元素的问题。对于Score类,计算分数时需要注意起始分数、访问房间数和解谜数的正确计算。 在生成代码时,必须严格按照文档中的方法签名来实现,比如Position的构造函数参数是int x和int y,Room的构造函数参数包括名称、描述、符号和位置。Map类需要初始化指定宽度和高度的地图数组,并在放置房间时更新对应位置的符号。 测试各个类时,需要注意是否符合jUnit测试的要求,比如字段和方法的命名是否正确,是否有额外的导入等。用户特别强调不能修改测试文件,所以生成的代码必须严格按照模板,不能有额外的库或修改现有结构。 可能的疑问是,如何在Map类中显示已探索的区域,可能需要维护一个已访问的标记,或者根据玩家移动来更新地图显示。此外,Game类中的命令解析需要处理不同的输入情况,比如大小写、参数数量等,确保命令解析正确。 最后,用户需要提交视频演示和代码,所以生成的代码需要结构清晰,注释明确,方便用户理解和演示。同时,必须避免任何抄袭或使用外部生成工具,确保代码的原创性。 </think>```java package org.uob.a1; public class Position { public int x; public int y; public Position(int x, int y) { this.x = x; this.y = y; } } ``` ```java package org.uob.a1; public class Room { private String name; private String description; private char symbol; private Position position; public Room(String name, String description, char symbol, Position position) { this.name = name; this.description = description; this.symbol = symbol; this.position = position; } public String getName() { return name; } public String getDescription() { return description; } public char getSymbol() { return symbol; } public Position getPosition() { return position; } } ``` ```java package org.uob.a1; public class Map { private final char EMPTY = '.'; private char[][] mapArray; private int width; private int height; public Map(int width, int height) { this.width = width; this.height = height; mapArray = new char[height][width]; for (int i = 0; i < height; i++) { for (int j = 0; j < width; j++) { mapArray[i][j] = EMPTY; } } } public void placeRoom(Position pos, char symbol) { if (pos.x >= 0 && pos.x < width && pos.y >= 0 && pos.y < height) { mapArray[pos.y][pos.x] = symbol; } } public String display() { StringBuilder sb = new StringBuilder(); for (int i = 0; i < height; i++) { for (int j = 0; j < width; j++) { sb.append(mapArray[i][j]); } sb.append("\n"); } return sb.toString(); } } ``` ```java package org.uob.a1; public class Inventory { final int MAX_ITEMS = 10; private String[] items = new String[MAX_ITEMS]; private int itemCount = 0; public Inventory() {} public void addItem(String item) { if (itemCount < MAX_ITEMS) { items[itemCount++] = item; } } public int hasItem(String item) { for (int i = 0; i < itemCount; i++) { if (items[i] != null && items[i].equals(item)) { return i; } } return -1; } public void removeItem(String item) { int index = hasItem(item); if (index != -1) { for (int i = index; i < itemCount - 1; i++) { items[i] = items[i + 1]; } items[--itemCount] = null; } } public String displayInventory() { StringBuilder sb = new StringBuilder("You have: "); for (int i = 0; i < itemCount; i++) { sb.append(items[i]).append(" "); } return sb.toString(); } } ``` ```java package org.uob.a1; public class Score { private final int PUZZLE_VALUE = 10; private int startingScore; private int currentScore; private int roomsVisited; private int puzzlesSolved; public Score(int startingScore) { this.startingScore = startingScore; this.currentScore = startingScore; } public void visitRoom() { roomsVisited++; currentScore = startingScore - roomsVisited + (puzzlesSolved * PUZZLE_VALUE); } public void solvePuzzle() { puzzlesSolved++; currentScore = startingScore - roomsVisited + (puzzlesSolved * PUZZLE_VALUE); } public double getScore() { return currentScore; } } ``` ```java package org.uob.a1; import java.util.Scanner; public class Game { public static void main(String[] args) { // 初始化游戏元素 Position startPos = new Position(0, 0); Room startRoom = new Room("Start Room", "You are in the starting room. There is a door to the south.", 'S', startPos); Map gameMap = new Map(10, 10); gameMap.placeRoom(startPos, 'S'); Inventory inventory = new Inventory(); Score score = new Score(100); // 游戏主循环 Scanner scanner = new Scanner(System.in); Position currentPlayerPos = startPos; Room currentRoom = startRoom; while (true) { System.out.print(">> "); String input = scanner.nextLine().toLowerCase(); String[] parts = input.split(" "); switch (parts[0]) { case "move": if (parts.length < 2) break; // 简单移动逻辑示例 if (parts[1].equals("south")) { currentPlayerPos.y += 1; // 实际应用中应检查房间是否存在 score.visitRoom(); } break; case "look": System.out.println(currentRoom.getDescription()); break; case "inventory": System.out.println(inventory.displayInventory()); break; case "map": System.out.println(gameMap.display()); break; case "score": System.out.println("SCORE: " + score.getScore()); break; case "help": System.out.println("Valid commands: move <direction>, look, inventory, map, score, quit"); break; case "quit": System.out.println("Game over"); scanner.close(); return; default: System.out.println("Unknown command"); } } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值